本文共 1360 字,大约阅读时间需要 4 分钟。
正好是学logging模块的时候遇到的。代码是这样的:
1 2 3 4 5 6 7 | logging.basicConfig(filename = 'test.log' , level = logging.DEBUG, format = '%(name)s %(asctime)s %(module)s-%(lineno)d [%(levelname)s]:%(message)s' , datefmt = '%Y-%m-%d %H:%M:%S' ) logging.warning( 'test warning' ) logging.info( 'test info' ) logging.debug( 'test debug' ) |
上面的logging.basicConfig()要一堆参数,而且实验了一下,貌似必须得用关键参数,不能偷懒。于是好奇看了一下help
1 2 3 4 5 | import logging help (logging.basicConfig) # 下面是help的头2行,后面就不贴了 Help on function basicConfig in module logging: basicConfig( * * kwargs) # 这里原来用的是非固定参数 |
一看,整个就是非固定参数,那么只能老实的一个一个写了。但是一想,这里**kwargs会把多传入的关键参数变成一个字典,那么问题来了:
既然要变成字典,那我直接定义个字典,传个字典进去呗。
1 2 3 4 5 6 7 8 9 10 11 | import logging # 想着把参数做定义成一个常量,放到配置文件里或者文件开头。另外format太长了先单独写。 LOG_FORMAT = '%(asctime)s %(module)s-%(lineno)d [%(levelname)s]:%(message)s' LOG_KWARGS = { 'filename' : 'test.log' , 'level' :logging.DEBUG, 'format' :LOG_FORMAT, 'datefmt' : '%Y-%m-%d %H:%M:%S' } logging.basicConfig( * * LOG_KWARGS) # 字典前也加上**就能传入字典作为参数了 logging.warning( 'test warning' ) logging.info( 'test info' ) logging.debug( 'test debug' ) |
既然字典能这么传参,那么数组也一样了。
1 2 3 4 5 6 | def deal_list( * args): print (args) def deal_dic( * * kwargs): print (kwargs) deal_list( * [ 1 , 2 , 3 , 4 , 5 ]) # *args是把参数都变成元组,所以这里打印出来得是一个元组 deal_dic( * * { 'a' : 1 , 'b' : 2 }) |