Ecco un'idea per una sottoclasse di dict che può modificare le chiavi. Questo è un semplice esempio autonomo che è proprio come un dict
ma non fa distinzione tra maiuscole e minuscole per le chiavi str
.Perché la mia idea non funziona in python2?
from functools import wraps
def key_fix_decorator(f):
@wraps(f)
def wrapped(self, *args, **kwargs):
if args and isinstance(args[0], str):
args = (args[0].lower(),) + args[1:]
return f(self, *args, **kwargs)
return wrapped
class LowerDict(dict):
pass
for method_name in '__setitem__', '__getitem__', '__delitem__', '__contains__', 'get', 'pop', 'setdefault':
new_method = key_fix_decorator(getattr(LowerDict, method_name))
setattr(LowerDict, method_name, new_method)
nota dev: se si copia il mio codice per i propri usi, è necessario implementare LowerDict.__init__
per verificare eventuali collisioni chiave - non ho preso la briga di includere che ai fini di questa domanda
Su python3 tutto sembra funziona benissimo:
>>> d = LowerDict(potato=123, spam='eggs')
>>> d['poTATo']
123
>>> d.pop('SPAm')
'eggs'
>>> d['A']
# KeyError: 'a'
In python2 essa non ha nemmeno l'importazione, qui è la traceback:
File "/tmp/thing.py", line 15, in <module>
new_method = key_fix_decorator(getattr(LowerDict, method_name))
File "/tmp/thing.py", line 4, in key_fix_decorator
@wraps(f)
File "/usr/lib/python2.7/functools.py", line 33, in update_wrapper
setattr(wrapper, attr, getattr(wrapped, attr))
AttributeError: 'wrapper_descriptor' object has no attribute '__module__'
Quale potrebbe essere il problema? Non riesco a vedere alcun codice specifico per la versione eccetto per la cosa str
/basestring
, che è solo un piccolo dettaglio, non un problema di rottura del codice.
La differenza è come 'update_wrapper' è implementato in entrambe le versioni.https: //hg.python.org/cpython/file/2.7/Lib/functools.py#l17 e https://hg.python.org/ cpython/file/3.4/Lib/functools.py # l43 –
Questo è probabilmente correlato: http://bugs.python.org/issue3445 –
Potresti anche essere interessato a PEP 455: https://www.python.org/ dev/peps/pep-0455 / –