Die **{0: 'constant', 1:'lambert'}
übergibt zwei Schlüssel/Wert-Schlüsselpaare als Schlüsselwortargumente an den Konstruktor defaultdict()
. Derselbe Konstruktor würde jedoch auch ein Wörterbuch als zweites Argument als Standard behandeln.
Als solches kann die **
ganz weggelassen werden, sowohl in der 2 und 3:
collections.defaultdict(lambda: 'blinn', {0: 'constant', 1:'lambert'})
Demo in Python 2 und zeigt Ihnen die gleiche Leistung erhalten:
>>> import sys
>>> sys.version_info
sys.version_info(major=2, minor=7, micro=12, releaselevel='final', serial=0)
>>> import collections
>>> collections.defaultdict(lambda: 'blinn', **{0: 'constant', 1:'lambert'}) == collections.defaultdict(lambda: 'blinn', {0: 'constant', 1:'lambert'})
True
>>> collections.defaultdict(lambda: 'blinn', **{0: 'constant', 1:'lambert'})
defaultdict(<function <lambda> at 0x102426410>, {0: 'constant', 1: 'lambert'})
>>> _[0]
'constant'
>>> collections.defaultdict(lambda: 'blinn', {0: 'constant', 1:'lambert'})
defaultdict(<function <lambda> at 0x102426410>, {0: 'constant', 1: 'lambert'})
>>> _[0]
'constant'
und in Python 3 :
>>> import sys
>>> sys.version_info
sys.version_info(major=3, minor=6, micro=0, releaselevel='beta', serial=3)
>>> import collections
>>> collections.defaultdict(lambda: 'blinn', {0: 'constant', 1:'lambert'})
defaultdict(<function <lambda> at 0x10e3589d8>, {0: 'constant', 1: 'lambert'})
>>> _[0]
'constant'
'map' ist' defaultdict'. Wenn Sie '**' verwenden, müssen die Schlüssel Strings sein - '" 0 "' und '" 1 "'. – furas