Heim  >  Artikel  >  Backend-Entwicklung  >  Tutorial zur Verwendung der Python-Standardbibliothekssammlungen

Tutorial zur Verwendung der Python-Standardbibliothekssammlungen

黄舟
黄舟Original
2017-02-04 16:49:131458Durchsuche

Einführung

Python stellt uns 4 grundlegende Datenstrukturen zur Verfügung: Liste, Tupel, Diktat, festgelegt, aber beim Umgang mit großen Datenmengen sind diese vier Datenstrukturen offensichtlich zu einfach. Beispielsweise ist die Einfügungseffizienz einer Liste als einseitig verknüpfte Liste in manchen Situationen relativ gering Ein angeordnetes Diktat. Daher müssen wir zu diesem Zeitpunkt das von der Python-Standardbibliothek bereitgestellte Sammlungspaket verwenden. Durch die Beherrschung dieser Sammlungsklassen können wir nicht nur den von uns geschriebenen Code pythonischer gestalten, sondern auch die Effizienz verbessern Unsere Programme laufen.

Verwendung von defaultdict

defaultdict (default_factory) fügt default_factory über dem gewöhnlichen Diktat (Wörterbuch) hinzu, sodass der entsprechende Schlüssel (Schlüssel) automatisch generiert wird, wenn Es existiert kein Typwert (Wert). Der Parameter default_factory kann als Liste angegeben werden. Set, int und andere zulässige Typen.

Beispiel1

>>> from collections import defaultdict
>>> s = [('red', 1), ('blue', 2), ('red', 3), ('blue', 4), ('red', 1), ('blue', 4)]

Wir haben jetzt eine Reihe von Listen (Listen) wie die obige, obwohl wir nach sorgfältiger Beobachtung 6 Datensätze haben Tatsächlich gibt es nur zwei Datensätze. Es gibt mehrere Farben, aber jede Farbe entspricht mehreren Werten. Jetzt wollen wir diese Liste in ein Diktat (Wörterbuch) umwandeln. Der Schlüssel (Schlüssel) dieses Diktats entspricht einer Farbe, und der Wert (Wert) des Diktats wird auf eine Liste gesetzt, um mehrere entsprechende Werte zu speichern zur Farbe. Wir können defaultdict(list) verwenden, um dieses Problem zu lösen.

# 
d可以看作一个dict(字典),dict的value是一个list(列表)
>>> d = defaultdict(list)
>>> for k, v in s:
...     d[k].append(v)
...
>>> d
defaultdict(<class &#39;list&#39;>, {&#39;blue&#39;: [2, 4, 4], &#39;red&#39;: [1, 3, 1]})

Beispiel2

Im obigen Beispiel gibt es einige Unvollkommenheiten, wie zum Beispiel {'blue': [2, 4, 4], 'red': [1, 3, 1]} In diesem Standarddikt enthält die blaue Farbe zwei 4er und die rote Farbe zwei 1er. Wir möchten jedoch keine doppelten Elemente enthalten. Zu diesem Zeitpunkt können wir die Verwendung von defaultdict(set) in Betracht ziehen, um dieses Problem zu lösen. Der Unterschied zwischen Set (Sammlung) und Liste (Liste) besteht darin, dass dieselben Elemente nicht in Set vorhanden sein dürfen.

>>> d = defaultdict(set)
>>> for k, v in s:
...     d[k].add(v)
...
>>> d
defaultdict(<class &#39;set&#39;>, {&#39;blue&#39;: {2, 4}, &#39;red&#39;: {1, 3}})

Beispiel3

>>> s = 
&#39;hello world&#39;

Durch die Verwendung der defaultdict(int)-Form zählen wir die Anzahl der Vorkommen jedes Zeichens in einer Zeichenfolge.

>>> d = defaultdict(int)
>>> for k in s:
...     d[k] += 1
...
>>> d
defaultdict(<class &#39;int&#39;>, {&#39;o&#39;: 2, &#39;h&#39;: 1, &#39;w&#39;: 1, &#39;l&#39;: 3, &#39; &#39;: 1, &#39;d&#39;: 1, &#39;e&#39;: 1, &#39;r&#39;: 1})

Verwendung von OrderedDict

Wir wissen, dass das Standarddikt (Wörterbuch) ungeordnet ist, aber in einigen Fällen müssen wir die Ordnung des Diktats beibehalten Zu diesem Zeitpunkt können Sie OrderedDict verwenden, eine Unterklasse von dict, die jedoch den geordneten Typ von dict auf der Grundlage von dict beibehält. Schauen wir uns an, wie man es verwendet.

Beispiel1

>>> from collections import OrderedDict
# 
无序的dict
>>> d = {&#39;banana&#39;: 3, &#39;apple&#39;: 4, &#39;pear&#39;: 1, &#39;orange&#39;: 2}

Dies ist ein ungeordnetes Diktat (Wörterbuch). Jetzt können wir OrderedDict verwenden, um dieses Diktat zu ordnen.

# 
将d按照key来排序
>>> OrderedDict(sorted(d.items(), key=lambda t: t[0]))
OrderedDict([(&#39;apple&#39;, 4), (&#39;banana&#39;, 3), (&#39;orange&#39;, 2), (&#39;pear&#39;, 1)])
# 
将d按照value来排序
>>> OrderedDict(sorted(d.items(), key=lambda t: t[1]))
OrderedDict([(&#39;pear&#39;, 1), (&#39;orange&#39;, 2), (&#39;banana&#39;, 3), (&#39;apple&#39;, 4)])
# 
将d按照key的长度来排序
>>> OrderedDict(sorted(d.items(), key=lambda t: len(t[0])))
OrderedDict([(&#39;pear&#39;, 1), (&#39;apple&#39;, 4), (&#39;orange&#39;, 2), (&#39;banana&#39;, 3)])

Beispiel2

Mit der Methode popitem(last=True) können wir die Schlüssel im Diktat in LIFO löschen (first in, last). out) order -value, d. h. das zuletzt eingefügte Schlüssel-Wert-Paar löschen. Wenn last=False, wird der Schlüsselwert im Diktat gemäß FIFO (First In, First Out) gelöscht.

>>> d = {&#39;banana&#39;: 3, &#39;apple&#39;: 4, &#39;pear&#39;: 1, &#39;orange&#39;: 2}
# 
将d按照key来排序
>>> d = OrderedDict(sorted(d.items(), key=lambda t: t[0]))
>>> d
OrderedDict([(&#39;apple&#39;, 4), (&#39;banana&#39;, 3), (&#39;orange&#39;, 2), (&#39;pear&#39;, 1)])
# 
使用popitem()方法来移除最后一个key-value对
>>> d.popitem()
(&#39;pear&#39;, 1)
# 
使用popitem(last=False)来移除第一个key-value对
>>> d.popitem(last=False)
(&#39;apple&#39;, 4)

Beispiel3

Verwenden Sie move_to_end(key, last=True), um die Schlüsselwertreihenfolge des geordneten OrderedDict-Objekts zu ändern. Mit dieser Methode können wir jeden Schlüsselwert im geordneten OrderedDict-Objekt am Anfang oder Ende des Wörterbuchs einfügen.

>>> d = OrderedDict.fromkeys(&#39;abcde&#39;)
>>> d
OrderedDict([(&#39;a&#39;, None), (&#39;b&#39;, None), (&#39;c&#39;, None), (&#39;d&#39;, None), (&#39;e&#39;, None)])
# 
将key为b的key-value对移动到dict的最后
>>> d.move_to_end(&#39;b&#39;)
>>> d
OrderedDict([(&#39;a&#39;, None), (&#39;c&#39;, None), (&#39;d&#39;, None), (&#39;e&#39;, None), (&#39;b&#39;, None)])
>>> &#39;&#39;.join(d.keys())
&#39;acdeb&#39;
# 
将key为b的key-value对移动到dict的最前面
>>> d.move_to_end(&#39;b&#39;, last=False)
>>> &#39;&#39;.join(d.keys())
&#39;bacde&#39;

Verwendung von deque

Der Vorteil der Listenspeicherung von Daten besteht darin, dass das Auffinden von Elementen anhand des Index schnell geht, das Einfügen und Löschen von Elementen jedoch sehr langsam. Ja, da es sich um eine einfach verknüpfte Listendatenstruktur handelt. Deque ist eine bidirektionale Liste zur effizienten Implementierung von Einfüge- und Löschvorgängen. Sie eignet sich für Warteschlangen und Stapel und ist threadsicher.

List bietet nur die Append- und Pop-Methoden zum Einfügen/Löschen von Elementen am Ende der Liste, aber deque fügt appendleft/popleft hinzu, damit wir Elemente am Anfang des Elements effizient einfügen/löschen können. Darüber hinaus beträgt die Algorithmuskomplexität bei der Verwendung von deque zum Hinzufügen (Anhängen) oder Entfernen (Pop) von Elementen an beiden Enden der Warteschlange etwa O(1), aber für die Operation des Listenobjekts zum Ändern der Listenlänge und der Datenposition, z Beispiel Die Komplexität der Operationen pop(0) und insert(0, v) ist so hoch wie O(n). Da die Operation von deque grundsätzlich mit der von list identisch ist, wird sie hier nicht wiederholt.

Verwendung von ChainMap

ChainMap wird verwendet, um mehrere Diktate (Wörterbücher) in einer Liste (nur eine Metapher) zusammenzufassen, was als Zusammenführung mehrerer Wörter verstanden werden kann Wörterbücher sind jedoch anders als aktualisiert und effizienter.

>>> from collections import ChainMap
>>> a = {&#39;a&#39;: &#39;A&#39;, &#39;c&#39;: &#39;C&#39;}
>>> b = {&#39;b&#39;: &#39;B&#39;, &#39;c&#39;: &#39;D&#39;}
>>> m = ChainMap(a, b)
# 
构造一个ChainMap对象
>>> m
ChainMap({&#39;a&#39;: &#39;A&#39;, &#39;c&#39;: &#39;C&#39;}, {&#39;b&#39;: &#39;B&#39;, &#39;c&#39;: &#39;D&#39;})
>>> m[&#39;a&#39;]
&#39;A&#39;
>>> m[&#39;b&#39;]
&#39;B&#39;
# 
将m变成一个list
>>> m.maps
[{&#39;a&#39;: &#39;A&#39;, &#39;c&#39;: &#39;C&#39;}, {&#39;b&#39;: &#39;B&#39;, &#39;c&#39;: &#39;D&#39;}]

# 
更新a中的值也会对ChainMap对象造成影响
>>> a[&#39;c&#39;] = &#39;E&#39;
>>> m[&#39;c&#39;]
&#39;E&#39;
# 
从m复制一个ChainMap对象,更新这个复制的对象并不会对m造成影响
>>> m2 = m.new_child()
>>> m2[&#39;c&#39;] = &#39;f&#39;
>>> m[&#39;c&#39;]
&#39;E&#39;
>>> a[&#39;c&#39;]
&#39;E&#39;
>>> m2.parents
ChainMap({&#39;a&#39;: &#39;A&#39;, &#39;c&#39;: &#39;C&#39;}, {&#39;b&#39;: &#39;B&#39;, &#39;c&#39;: &#39;D&#39;})

Verwendung von Counter

Beispiel1

Counter ist ebenfalls eine Unterklasse von dict Es ist ein ungeordneter Container und kann als Zähler betrachtet werden, der zum Zählen der Anzahl verwandter Elemente verwendet wird.

>>> from collections import Counter
>>> cnt = Counter()
# 
统计列表中元素出现的个数
>>> for word in [&#39;red&#39;, &#39;blue&#39;, &#39;red&#39;, &#39;green&#39;, &#39;blue&#39;, &#39;blue&#39;]:
...  cnt[word] += 1
...
>>> cnt
Counter({&#39;blue&#39;: 3, &#39;red&#39;: 2, &#39;green&#39;: 1})
# 
统计字符串中元素出现的个数
>>> cnt = Counter()
>>> for ch in &#39;hello&#39;:
...     cnt[ch] = cnt[ch] + 1
...
>>> cnt
Counter({&#39;l&#39;: 2, &#39;o&#39;: 1, &#39;h&#39;: 1, &#39;e&#39;: 1})

Beispiel2

Verwenden Sie die Methode elements(), um einen Iterator (Iterator) entsprechend der Anzahl der Vorkommen der Elemente zurückzugeben Beliebige Reihenfolge. Wenn die Anzahl der Elemente kleiner als 1 ist, wird sie ignoriert.

>>> c = Counter(a=4, b=2, c=0, d=-2)
>>> c
Counter({&#39;a&#39;: 4, &#39;b&#39;: 2, &#39;c&#39;: 0, &#39;d&#39;: -2})
>>> c.elements()
<itertools.chain object at 0x7fb0a069ccf8>
>>> next(c)
&#39;a&#39;
# 
排序
>>> sorted(c.elements())
[&#39;a&#39;, &#39;a&#39;, &#39;a&#39;, &#39;a&#39;, &#39;b&#39;, &#39;b&#39;]

Verwenden Sie most_common(n), um eine Liste zurückzugeben, die die ersten n Elemente enthält, die im Counter-Objekt erscheinen.

>>> c = Counter(&#39;abracadabra&#39;)
>>> c
Counter({&#39;a&#39;: 5, &#39;b&#39;: 2, &#39;r&#39;: 2, &#39;d&#39;: 1, &#39;c&#39;: 1})
>>> c.most_common(3)
[(&#39;a&#39;, 5), (&#39;b&#39;, 2), (&#39;r&#39;, 2)]

Verwendung von „namedtuple“

Verwenden Sie „namedtuple(typename, field_names)“, um die Elemente im Tupel zu benennen und das Programm besser lesbar zu machen.

>>> from collections import namedtuple
>>> Point = namedtuple(&#39;PointExtension&#39;, [&#39;x&#39;, &#39;y&#39;])
>>> p = Point(1, 2)
>>> p.__class__.__name__
&#39;PointExtension&#39;
>>> p.x
1
>>> p.y
2

Das Obige ist der Inhalt des Sammlungsnutzungs-Tutorials der Python-Standardbibliothek. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


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