Eu não acho que você precise defaultdict
aqui. Por que não apenas usar o dict.setdefault
método?
>>> d = {}
>>> d.setdefault('p', C('p')).v
'p'
Isso, é claro, criaria muitas instâncias de C
. Caso seja um problema, acho que a abordagem mais simples servirá:
>>> d = {}
>>> if 'e' not in d: d['e'] = C('e')
Seria mais rápido do que o defaultdict
ou qualquer outra alternativa, pelo que posso ver.
ETA em relação à velocidade do in
teste versus o uso da cláusula try-except:
>>> def g():
d = {}
if 'a' in d:
return d['a']
>>> timeit.timeit(g)
0.19638929363557622
>>> def f():
d = {}
try:
return d['a']
except KeyError:
return
>>> timeit.timeit(f)
0.6167065411074759
>>> def k():
d = {'a': 2}
if 'a' in d:
return d['a']
>>> timeit.timeit(k)
0.30074866358404506
>>> def p():
d = {'a': 2}
try:
return d['a']
except KeyError:
return
>>> timeit.timeit(p)
0.28588609450770264