3 回答

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超5個(gè)贊
您可以為默認(rèn)值傳遞給get()不在字典中的鍵:
self.val2 = kwargs.get('val2',"default value")
但是,如果您計(jì)劃使用具有特定默認(rèn)值的特定參數(shù),為什么不首先使用命名參數(shù)?
def __init__(self, val2="default value", **kwargs):

TA貢獻(xiàn)1934條經(jīng)驗(yàn) 獲得超2個(gè)贊
雖然大多數(shù)答案都是這樣說的,例如,
def f(**kwargs):
foo = kwargs.pop('foo')
bar = kwargs.pop('bar')
...etc...
是相同的”
def f(foo=None, bar=None, **kwargs):
...etc...
這不是真的。在后一種情況下,f可以稱為f(23, 42),而前者的情況下接受命名的參數(shù)只有 -沒有位置的調(diào)用。通常,您希望允許調(diào)用者具有最大的靈活性,因此第二種形式(因?yàn)榇蠖鄶?shù)答案斷言)更可?。旱闆r并非總是如此。當(dāng)你接受許多可選參數(shù)時(shí),通常只有少數(shù)幾個(gè)被傳遞,這可能是一個(gè)很好的想法(避免在你的呼叫站點(diǎn)發(fā)生意外和不可讀的代碼?。﹣?lái)強(qiáng)制使用命名參數(shù) - threading.Thread就是一個(gè)例子。第一種形式是如何在Python 2中實(shí)現(xiàn)它。
成語(yǔ)是如此重要,以至于在Python 3現(xiàn)在有特殊的支持語(yǔ)法:?jiǎn)魏竺總€(gè)參數(shù)*的def簽名關(guān)鍵字只,也就是說,不能被作為位置參數(shù)傳遞,但只是作為一個(gè)命名的。所以在Python 3中你可以將上面的代碼編寫為:
def f(*, foo=None, bar=None, **kwargs):
...etc...
實(shí)際上,在Python 3中,您甚至可以使用非關(guān)鍵字的參數(shù),這些參數(shù)不是可選的(沒有默認(rèn)值的參數(shù))。
但是,Python 2仍然有很長(zhǎng)一段時(shí)間的生產(chǎn)生活,所以最好不要忘記讓你在Python 2中實(shí)現(xiàn)的技巧和習(xí)慣用法在Python 3中直接支持的重要設(shè)計(jì)思想!

TA貢獻(xiàn)1851條經(jīng)驗(yàn) 獲得超5個(gè)贊
我建議這樣的事情
def testFunc( **kwargs ):
options = {
'option1' : 'default_value1',
'option2' : 'default_value2',
'option3' : 'default_value3', }
options.update(kwargs)
print options
testFunc( option1='new_value1', option3='new_value3' )
# {'option2': 'default_value2', 'option3': 'new_value3', 'option1': 'new_value1'}
testFunc( option2='new_value2' )
# {'option1': 'default_value1', 'option3': 'default_value3', 'option2': 'new_value2'}
然后以您想要的任何方式使用值
dictionaryA.update(dictionaryB)添加內(nèi)容dictionaryB以dictionaryA覆蓋任何重復(fù)的鍵。
添加回答
舉報(bào)