Heim  >  Artikel  >  Backend-Entwicklung  >  Unterstützt das Python-Wörterbuch die bidirektionale Indizierung?

Unterstützt das Python-Wörterbuch die bidirektionale Indizierung?

anonymity
anonymityOriginal
2019-06-15 13:20:2911318Durchsuche

Dictionary in Python ist ein weiteres veränderbares Containermodell und kann jede Art von Objekt speichern. Jedes Schlüssel-Wert-Paar (key=>value) im Wörterbuch wird durch einen Doppelpunkt (:) und jedes Paar durch ein Komma (,) getrennt. Das gesamte Wörterbuch ist in geschweifte Klammern ({}) eingeschlossen Wenn das Wörterbuch ungeordnet ist, drücken Sie die Taste, um den Wert abzurufen.

Unterstützt das Python-Wörterbuch die bidirektionale Indizierung?

Das Wörterbuchmodul stellt drei Klassen zur Verfügung, um einige Operationen von Eins-zu-Eins-Zuordnungstypen zu verarbeiten

'bidict', 'inverted', 'namedbidict'

>>> import bidict
>>> dir(bidict)
['MutableMapping', '_LEGALNAMEPAT', '_LEGALNAMERE', '__builtins__', '__doc__', 
'__file__', '__name__', '__package__', 'bidict', 'inverted', 'namedbidict', 're', 'wraps']

1.bidict-Klasse:

>>> from bidict import bidict
>>> D=bidict({'a':'b'})
>>> D['a']
'b'
>>> D[:'b']
'a'
>>> ~D        #反转字典
bidict({'b': 'a'})
>>> dict(D)    #转为普通字典
{'a': 'b'}
>>> D['c']='c'   #添加元素,普通字典的方法都可以用
>>> D
bidict({'a': 'b', 'c': 'c'})

2.invertierte Klasse, invertieren Sie den Schlüsselwert des Wörterbuchs

>>> seq = [(1, 'one'), (2, 'two'), (3, 'three')]
>>> list(inverted(seq))
    [('one', 1), ('two', 2), ('three', 3)]

3.namedbidict(mapname, fwdname, invname):

>>> CoupleMap = namedbidict('CoupleMap', 'husbands', 'wives')
>>> famous = CoupleMap({'bill': 'hillary'})
>>> famous.husbands['bill']
'hillary'
>>> famous.wives['hillary']
'bill'
>>> famous.husbands['barack'] = 'michelle'
>>> del famous.wives['hillary']
>>> famous
CoupleMap({'barack': 'michelle'})

Das obige ist der detaillierte Inhalt vonUnterstützt das Python-Wörterbuch die bidirektionale Indizierung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn