Detaillierte Erläuterung der Verwendung von Funktionen der items()-Serie in Python

Y2J
Freigeben: 2017-05-17 15:11:37
Original
14361 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich die Verwendung der Dictionary-Items()-Funktionsreihe in Python vor. Es handelt sich um eine sehr praktische Funktion.

Dieser Artikel beschreibt die Verwendung Die Funktionsreihe dictionary items() in Python mit Beispielen hat einen guten Referenzwert für die Python-Programmierung. Die spezifische Analyse lautet wie folgt:

Schauen wir uns zunächst ein Beispiel an:

import html  # available only in Python 3.x 
def make_elements(name, value, **attrs): 
  keyvals = [' %s="%s"' % item for item in attrs.items()] 
  attr_str = ''.join(keyvals) 
  element = &#39;<{name}{attrs}>{value}</{name}>&#39;.format( 
      name = name, 
      attrs = attr_str, 
      value = html.escape(value)) 
  return element 
make_elements(&#39;item&#39;, &#39;Albatross&#39;, size=&#39;large&#39;, quantity=6) 
make_elements(&#39;p&#39;, &#39;<spam>&#39;)
Nach dem Login kopieren

Die Funktion dieses Programms ist sehr einfach, nämlich HTML-Tags zu generieren . Beachten Sie, dass das HTML-Modul nur in Python 3.x verwendet werden kann.

Zuerst ist mir gerade aufgefallen, dass der Wörterbuchtyp Variable der Schlüsselwörter, die die Tag--Attribut--Liste generieren, auf interessante Weise aufgebaut ist. Zwei %s entsprechen einem Artikel, also Nachdem ich die relevanten Informationen überprüft habe, habe ich viele Dinge herausgefunden, die ich hier zusammenfassen werde.

Hinweis: Für die Versionen, die von allen unten aufgeführten Python-Interpretern verwendet werden, entspricht 2.x 2.7.3 und 3.x entspricht 3.4.1
In Python 2.x Elemente in der offiziellen Dokumentation Die Methode ist wie folgt: Generieren Sie eine Liste von (Schlüssel-Wert-)Paaren wie folgt:

>>> d = {&#39;size&#39;: &#39;large&#39;, &#39;quantity&#39;: 6} 
>>> d.items() 
[(&#39;quantity&#39;, 6), (&#39;size&#39;, &#39;large&#39;)]
Nach dem Login kopieren

Bei der Suche nach habe ich zufällig so eins gesehen Stackoverflow-Frage: Was ist der Unterschied zwischen dict.items() und dict.iteritems()? , die erste Antwort bedeutet ungefähr Folgendes:

„Zuerst gab items() eine Liste mit allen Elementen von dict wie oben zurück, aber da dies zu viel Speicher verschwendete, wurde es später hinzugefügt ( Hinweis: Die Gruppe der Funktionen iteritems(), iterkeys() und itervalues(), die in Python 2.2 auftauchten, wird verwendet, um einen Iterator zurückzugeben, um Speicher zu sparen, aber in 3.x gibt items() selbst einen solchen Iterator zurück Das Verhalten von items() in 3.x stimmt mit dem Verhalten von iteritems() in 2.x überein, und die Funktion iteritems() wurde abgeschafft. „

Aber es ist interessanter Diese Antwort wurde akzeptiert. Die folgenden Kommentare weisen darauf hin, dass diese Aussage nicht korrekt ist. Das Verhalten von items() in 3.x unterscheidet sich vom Verhalten von iteritems() in 2.x Objekt

“, dieses Objekt kann Änderungen im Diktat widerspiegeln. Später wurde eine weitere Funktion viewitems() zu Python 2.7 und dieses Verhalten in 3.x hinzugefügt, um konsistent zu sein Um die Ansprüche in zu bestätigen Den Kommentaren zufolge habe ich den folgenden Test durchgeführt und dabei auf die im Test verwendete Python-Version geachtet:
Test 1 (Python 2.7.3):

Test 2 (Python 3.4. 1):
Python 2.7.3 (default, Feb 27 2014, 19:58:35)  
[GCC 4.6.3] on linux2 
Type "help", "copyright", "credits" or "license" for more information. 
>>> d = {&#39;size&#39;: &#39;large&#39;, &#39;quantity&#39;: 6} 
>>> il = d.items() 
>>> it = d.iteritems() 
>>> vi = d.viewitems() 
>>> il 
[(&#39;quantity&#39;, 6), (&#39;size&#39;, &#39;large&#39;)] 
>>> it 
<dictionary-itemiterator object at 0x7fe555159f18> 
>>> vi 
dict_items([(&#39;quantity&#39;, 6), (&#39;size&#39;, &#39;large&#39;)])
Nach dem Login kopieren

Sie können sehen, dass in Python 3.x die beiden Methoden iteritems() und viewitems() abgeschafft wurden und item() Das erhaltene Ergebnis stimmt mit viewitems() in überein 2.x.
Python 3.4.1 (default, Aug 12 2014, 16:43:01)  
[GCC 4.9.0] on linux 
Type "help", "copyright", "credits" or "license" for more information. 
>>> d = {&#39;size&#39;: &#39;large&#39;, &#39;quantity&#39;: 6} 
>>> il = d.items() 
>>> it = d.iteritems() 
Traceback (most recent call last): 
 File "<stdin>", line 1, in <module> 
AttributeError: &#39;dict&#39; object has no attribute &#39;iteritems&#39; 
>>> vi = d.viewitems() 
Traceback (most recent call last): 
 File "<stdin>", line 1, in <module> 
AttributeError: &#39;dict&#39; object has no attribute &#39;viewitems&#39; 
>>> il 
dict_items([(&#39;size&#39;, &#39;large&#39;), (&#39;quantity&#39;, 6)])
Nach dem Login kopieren
Der von iteritems() und viewitems() in 2.x zurückgegebene Inhalt kann mit for durchlaufen werden.


Was ist der Unterschied zwischen den beiden? viewitems() gibt das Ansichtsobjekt zurück, das Änderungen im Wörterbuch widerspiegeln kann. Wenn Sie beispielsweise im obigen Beispiel eine Schlüssel-Wert-Kombination zu d hinzufügen, bevor Sie die beiden Variablen it und vi verwenden, ist der Unterschied leicht zu erkennen . .
>>> for k, v in it: 
...  print k, v 
...  
quantity 6 
size large 
>>> for k, v in vi: 
...  print k, v 
...  
quantity 6 
size large
Nach dem Login kopieren

In der dritten Zeile haben wir ein neues Element in d eingefügt, vi kann weiter durchlaufen, und die neue Durchquerung kann die Änderungen in d widerspiegeln, aber beim Durchlaufen wird ein Fehler gemeldet Es fordert dazu auf dass sich die Größe des Wörterbuchs während des Durchlaufs ändert und der Durchlauf fehlschlägt.
>>> it = d.iteritems() 
>>> vi = d.viewitems() 
>>> d[&#39;newkey&#39;] = &#39;newvalue&#39; 
>>> d 
{&#39;newkey&#39;: &#39;newvalue&#39;, &#39;quantity&#39;: 6, &#39;size&#39;: &#39;large&#39;} 
>>> vi 
dict_items([(&#39;newkey&#39;, &#39;newvalue&#39;), (&#39;quantity&#39;, 6), (&#39;size&#39;, &#39;large&#39;)]) 
>>> it 
<dictionary-itemiterator object at 0x7f50ab898f70> 
>>> for k, v in vi: 
...  print k, v 
...  
newkey newvalue 
quantity 6 
size large 
>>> for k, v in it: 
...  print k, v 
...  
Traceback (most recent call last): 
 File "<stdin>", line 1, in <module> 
RuntimeError: dictionary changed size during iteration
Nach dem Login kopieren

Zusammenfassend lässt sich sagen, dass in 2.x ursprünglich die Methode items() verwendet wurde, aber weil sie zu viel Speicher verschwendete, wurde in 3.x die Methode iteritems() hinzugefügt, um einen Iterator zurückzugeben. Die Methode items() wurde hinzugefügt, um ein Ansichtsobjekt zurückzugeben, sodass das zurückgegebene Objekt auch Änderungen im ursprünglichen Wörterbuch widerspiegeln kann. Gleichzeitig wurde die Abwärtskompatibilitätsfunktion von viewitems() hinzugefügt in 2.7.

In 3.x müssen Sie sich also keine Gedanken über die Unterschiede zwischen den drei machen, da nur eine Methode items() beibehalten wird.


Ich glaube, dass die in diesem Artikel beschriebenen Beispiele einen gewissen Referenzwert für die Python-Programmierung aller haben.

【Verwandte Empfehlungen】

1.

Besondere Empfehlung: Version „php Programmer Toolbox“ V0.1 herunterladen2.

Kostenloses Python-Video-Tutorial

3.

Items()-Methode für eine grundlegende Einführung in Python

4. Beispiel für die Funktion item() im Python-Wörterbuch

5. Einführung in drei Methoden für den Zugriff auf das Wörterbuch

6. Der Unterschied zwischen iteriitems und Artikeln in sortiert

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Verwendung von Funktionen der items()-Serie in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle: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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage