--Il semble que la clé de hachage puisse être supérieure ou inférieure. C'est pratique. C'est un module, pas un simple python. Il s'appelle CaseInsensitive Dict.
pip install requests '' `` à l'avance.>>> from requests.structures import CaseInsensitiveDict
>>> cid = CaseInsensitiveDict({'Apple': 'osx', 'NeXT': 'STEP'})
>>> cid
{'Apple': 'osx', 'NeXT': 'STEP'}
>>> cid['apple']
'osx'
>>> cid['APPLE']
'osx'
>>> cid['next']
'STEP'
>>> cid['nEXT']
'STEP'
--S'il s'agit de perl, "" sera renvoyé s'il n'est pas en hachage, mais s'il s'agit de python, une erreur se produira. (Gênant ...)
>>> cid['microsoft']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "〜〜/python3.5/site-packages/requests/structures.py", line 54, in __getitem__
return self._store[key.lower()][1]
KeyError: 'microsoft'
--J'étais faché ...
--Il semble que vous puissiez utiliser l'opérateur in et la méthode has_key pour vérifier l'existence de la clé ... --CaseInsensitiveDict semble avoir des restrictions. --has_key n'a pas été préparé.
has_key
>>> cid.has_key('microsoft')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'CaseInsensitiveDict' object has no attribute 'has_key'
Si c'est le cas, ça va.
in
>>> 'microsoft' in cid
False
>>> 'apple' in cid
True
>>> 'Apple' in cid
True
--Utilisez un module appelé Hash :: Case :: Preserve. ――Il semble que le comportement en l'absence de clé soit le même que le hachage brut.
cid.pl
use Hash::Case::Preserve;
tie my(%cid),'Hash::Case::Preserve';
$cid{'NeXT'} = 'STEP';
$cid{'Apple'} = 'osx';
print $cid{'next'};
print $cid{'APPLE'};
print $cid{'microsoft'};
print keys %cid
sh-3.2$ perl -l cid.pl
STEP
osx
AppleNeXT
Recommended Posts