天天看点

Python直接用字典数组导入到函数的非固定参数

正好是学logging模块的时候遇到的。代码是这样的:

1

2

3

4

5

6

7

<code>logging.basicConfig(filename</code><code>=</code><code>'test.log'</code><code>,</code>

<code>                    </code><code>level</code><code>=</code><code>logging.DEBUG,</code>

<code>                    </code><code>format</code><code>=</code><code>'%(name)s %(asctime)s %(module)s-%(lineno)d [%(levelname)s]:%(message)s'</code><code>,</code>

<code>                    </code><code>datefmt</code><code>=</code><code>'%Y-%m-%d %H:%M:%S'</code><code>)</code>

<code>logging.warning(</code><code>'test warning'</code><code>)</code>

<code>logging.info(</code><code>'test info'</code><code>)</code>

<code>logging.debug(</code><code>'test debug'</code><code>)</code>

上面的logging.basicConfig()要一堆参数,而且实验了一下,貌似必须得用关键参数,不能偷懒。于是好奇看了一下help

<code>import</code> <code>logging</code>

<code>help</code><code>(logging.basicConfig)</code>

<code># 下面是help的头2行,后面就不贴了</code>

<code>Help</code> <code>on function basicConfig </code><code>in</code> <code>module logging:</code>

<code>basicConfig(</code><code>*</code><code>*</code><code>kwargs)  </code><code># 这里原来用的是非固定参数</code>

一看,整个就是非固定参数,那么只能老实的一个一个写了。但是一想,这里**kwargs会把多传入的关键参数变成一个字典,那么问题来了:

既然要变成字典,那我直接定义个字典,传个字典进去呗。

8

9

10

11

<code># 想着把参数做定义成一个常量,放到配置文件里或者文件开头。另外format太长了先单独写。</code>

<code>LOG_FORMAT </code><code>=</code> <code>'%(asctime)s %(module)s-%(lineno)d [%(levelname)s]:%(message)s'</code>

<code>LOG_KWARGS </code><code>=</code> <code>{</code><code>'filename'</code><code>:</code><code>'test.log'</code><code>,</code>

<code>              </code><code>'level'</code><code>:logging.DEBUG,</code>

<code>              </code><code>'format'</code><code>:LOG_FORMAT,</code>

<code>              </code><code>'datefmt'</code><code>:</code><code>'%Y-%m-%d %H:%M:%S'</code><code>}</code>

<code>logging.basicConfig(</code><code>*</code><code>*</code><code>LOG_KWARGS)  </code><code># 字典前也加上**就能传入字典作为参数了</code>

既然字典能这么传参,那么数组也一样了。

<code>def</code> <code>deal_list(</code><code>*</code><code>args):</code>

<code>    </code><code>print</code><code>(args)</code>

<code>def</code> <code>deal_dic(</code><code>*</code><code>*</code><code>kwargs):</code>

<code>    </code><code>print</code><code>(kwargs)</code>

<code>deal_list(</code><code>*</code><code>[</code><code>1</code><code>,</code><code>2</code><code>,</code><code>3</code><code>,</code><code>4</code><code>,</code><code>5</code><code>])  </code><code># *args是把参数都变成元组,所以这里打印出来得是一个元组</code>

<code>deal_dic(</code><code>*</code><code>*</code><code>{</code><code>'a'</code><code>:</code><code>1</code><code>,</code><code>'b'</code><code>:</code><code>2</code><code>})</code>

<code></code>

本文转自骑士救兵51CTO博客,原文链接:http://blog.51cto.com/steed/1982184,如需转载请自行联系原作者