正好是学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
})
|
本文转自骑士救兵51CTO博客,原文链接:http://blog.51cto.com/steed/1982184
,如需转载请自行联系原作者