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

Tutorial zur Verwendung der Python-Standardbibliothekssammlungen

Feb 04, 2017 pm 04:49 PM

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)]
Nach dem Login kopieren

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]})
Nach dem Login kopieren

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}})
Nach dem Login kopieren

Beispiel3

>>> s = 
&#39;hello world&#39;
Nach dem Login kopieren

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})
Nach dem Login kopieren

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}
Nach dem Login kopieren

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)])
Nach dem Login kopieren

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)
Nach dem Login kopieren

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;
Nach dem Login kopieren

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;})
Nach dem Login kopieren

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})
Nach dem Login kopieren

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;]
Nach dem Login kopieren

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)]
Nach dem Login kopieren

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
Nach dem Login kopieren

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


Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP und Python: Verschiedene Paradigmen erklärt PHP und Python: Verschiedene Paradigmen erklärt Apr 18, 2025 am 12:26 AM

PHP ist hauptsächlich prozedurale Programmierung, unterstützt aber auch die objektorientierte Programmierung (OOP). Python unterstützt eine Vielzahl von Paradigmen, einschließlich OOP, funktionaler und prozeduraler Programmierung. PHP ist für die Webentwicklung geeignet, und Python eignet sich für eine Vielzahl von Anwendungen wie Datenanalyse und maschinelles Lernen.

Wählen Sie zwischen PHP und Python: Ein Leitfaden Wählen Sie zwischen PHP und Python: Ein Leitfaden Apr 18, 2025 am 12:24 AM

PHP eignet sich für Webentwicklung und schnelles Prototyping, und Python eignet sich für Datenwissenschaft und maschinelles Lernen. 1.PHP wird für die dynamische Webentwicklung verwendet, mit einfacher Syntax und für schnelle Entwicklung geeignet. 2. Python hat eine kurze Syntax, ist für mehrere Felder geeignet und ein starkes Bibliotheksökosystem.

Kann gegen Code in Windows 8 ausgeführt werden Kann gegen Code in Windows 8 ausgeführt werden Apr 15, 2025 pm 07:24 PM

VS -Code kann unter Windows 8 ausgeführt werden, aber die Erfahrung ist möglicherweise nicht großartig. Stellen Sie zunächst sicher, dass das System auf den neuesten Patch aktualisiert wurde, und laden Sie dann das VS -Code -Installationspaket herunter, das der Systemarchitektur entspricht und sie wie aufgefordert installiert. Beachten Sie nach der Installation, dass einige Erweiterungen möglicherweise mit Windows 8 nicht kompatibel sind und nach alternativen Erweiterungen suchen oder neuere Windows -Systeme in einer virtuellen Maschine verwenden müssen. Installieren Sie die erforderlichen Erweiterungen, um zu überprüfen, ob sie ordnungsgemäß funktionieren. Obwohl VS -Code unter Windows 8 möglich ist, wird empfohlen, auf ein neueres Windows -System zu upgraden, um eine bessere Entwicklungserfahrung und Sicherheit zu erzielen.

Ist die VSCODE -Erweiterung bösartig? Ist die VSCODE -Erweiterung bösartig? Apr 15, 2025 pm 07:57 PM

VS -Code -Erweiterungen stellen böswillige Risiken dar, wie das Verstecken von böswilligem Code, das Ausbeutetieren von Schwachstellen und das Masturbieren als legitime Erweiterungen. Zu den Methoden zur Identifizierung böswilliger Erweiterungen gehören: Überprüfung von Verlegern, Lesen von Kommentaren, Überprüfung von Code und Installation mit Vorsicht. Zu den Sicherheitsmaßnahmen gehören auch: Sicherheitsbewusstsein, gute Gewohnheiten, regelmäßige Updates und Antivirensoftware.

So führen Sie Programme in der terminalen VSCODE aus So führen Sie Programme in der terminalen VSCODE aus Apr 15, 2025 pm 06:42 PM

Im VS -Code können Sie das Programm im Terminal in den folgenden Schritten ausführen: Erstellen Sie den Code und öffnen Sie das integrierte Terminal, um sicherzustellen, dass das Codeverzeichnis mit dem Terminal Working -Verzeichnis übereinstimmt. Wählen Sie den Befehl aus, den Befehl ausführen, gemäß der Programmiersprache (z. B. Pythons Python your_file_name.py), um zu überprüfen, ob er erfolgreich ausgeführt wird, und Fehler auflösen. Verwenden Sie den Debugger, um die Debugging -Effizienz zu verbessern.

Kann Visual Studio -Code in Python verwendet werden Kann Visual Studio -Code in Python verwendet werden Apr 15, 2025 pm 08:18 PM

VS -Code kann zum Schreiben von Python verwendet werden und bietet viele Funktionen, die es zu einem idealen Werkzeug für die Entwicklung von Python -Anwendungen machen. Sie ermöglichen es Benutzern: Installation von Python -Erweiterungen, um Funktionen wie Code -Abschluss, Syntax -Hervorhebung und Debugging zu erhalten. Verwenden Sie den Debugger, um Code Schritt für Schritt zu verfolgen, Fehler zu finden und zu beheben. Integrieren Sie Git für die Versionskontrolle. Verwenden Sie Tools für die Codeformatierung, um die Codekonsistenz aufrechtzuerhalten. Verwenden Sie das Lining -Tool, um potenzielle Probleme im Voraus zu erkennen.

Kann VSCODE für MAC verwendet werden Kann VSCODE für MAC verwendet werden Apr 15, 2025 pm 07:36 PM

VS -Code ist auf Mac verfügbar. Es verfügt über leistungsstarke Erweiterungen, GIT -Integration, Terminal und Debugger und bietet auch eine Fülle von Setup -Optionen. Für besonders große Projekte oder hoch berufliche Entwicklung kann VS -Code jedoch Leistung oder funktionale Einschränkungen aufweisen.

Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Apr 16, 2025 am 12:12 AM

Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

See all articles