正好是學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,如需轉載請自行聯系原作者