Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erklärung des Unterschieds zwischen Python3.x und Python2.x

Detaillierte Erklärung des Unterschieds zwischen Python3.x und Python2.x

巴扎黑
巴扎黑Original
2017-04-05 14:00:332514Durchsuche

Python3.x ist ein revolutionäres Upgrade von Python, das viele bisherige Funktionen abschafft und neue Funktionen einführt. Nicht vollständig kompatibel mit altem Code von 1.x und 2.x.

Python2.x ist abwärtskompatibel und die neueste Version ist Python 2.7. Darunter wurden die Versionen 2.6 und 2.7 veröffentlicht, um Python einen reibungslosen Übergang zu 3.X zu ermöglichen, und außerdem wurden einige 3.X-Funktionen hinzugefügt.

Derzeit unterstützen viele Bibliotheken 3.x nicht (z. B. Django, wxPython) und die meisten Anwendungen basieren immer noch auf 2.x. Anfängern wird die Verwendung der Version 2.7 empfohlen.

Hier sind einige Hauptunterschiede zwischen Python 3.X und 2.X

1. Leistung
Py3.0 führt den Pystone-Benchmark 30 % langsamer aus als Py2.5. Guido glaubt, dass Py3.0 viel Raum für Optimierung bietet und String- und Integer-Operationen ausführen kann
um gute Optimierungsergebnisse zu erzielen.
Die Leistung von Py3.1 ist 15 % langsamer als die von Py2.5, und es gibt noch viel Raum für Verbesserungen.

2. Kodierung
Py3.X-Quellcodedateien verwenden standardmäßig die UTF-8-Codierung, wodurch der folgende Code zulässig ist:
>>> China = 'China'
>>>print(China)
China

3. Grammatik
1) <> entfernt und alles durch !=
ersetzt 2) Entfernen Sie `` und verwenden Sie stattdessen repr()
. 3) Fügen Sie die Schlüsselwörter as und with as sowie True, False und None hinzu
4) Ganzzahlige Division gibt eine Gleitkommazahl zurück, um ein ganzzahliges Ergebnis zu erhalten, verwenden Sie bitte //
5) Nichtlokale Anweisung hinzufügen. Periphere (nicht globale) Variablen können direkt mit noclocal x
zugewiesen werden 6) Entfernen Sie die print-Anweisung und fügen Sie die Funktion print() hinzu, um dieselbe Funktion zu erreichen. Das Gleiche gilt für die exec-Anweisung, die in die exec()-Funktion
geändert wurde Zum Beispiel:
2.X: drucke „Die Antwort ist“, 2*2
3.X: print("Die Antwort ist", 2*2)
2.X: x drucken, 3.X: print(x, end=" ") # Verwenden Sie Leerzeichen, um Zeilen zu ersetzen
                                                                                                                            2.X: print >>sys.stderr, „schwerwiegender Fehler“
3.X: print("schwerwiegender Fehler", file=sys.stderr)
                                                       3.X: print((x, y)) # Anders als print(x, y)!
7) Das Verhalten von sequentiellen Operatoren wie x zurückzugeben 8) Die Eingabefunktion hat sich geändert, raw_input wurde gelöscht und durch Eingabe ersetzt:
2.X:guess = int(raw_input('Geben Sie eine Ganzzahl ein: ')) # Methode zum Lesen von Tastatureingaben
3.X:guess = int(input('Geben Sie eine Ganzzahl ein: '))

9) Entfernen Sie das Entpacken der Tupelparameter. Sie können die Funktion nicht wie def(a, (b, c)):pass
definieren 10) Neue oktale Wortvariable, die Funktion oct() wurde entsprechend geändert.
2. Die Methode von X lautet wie folgt:
>>> 0666
438
>>> oct(438)
'0666'
3.X so:
>>> 0666
SyntaxError: ungültiges Token (, Zeile 1)
>>> 0o666
438
>>> oct(438)
'0o666'
11) Binäre Literale und bin()-Funktion
hinzugefügt >>> bin(438)
'0b110110110'
>>> _438 = '0b110110110'
>>> _438
'0b110110110'
12) Erweitertes iterierbares Entpacken. In Py3. Objekte und seq sind iterierbar.
13) Das neue super() kann keine Parameter mehr an super() übergeben,
>>> Klasse C(Objekt):
             def __init__(self, a):
                                 print('C', a)
>>> Klasse D(C):
             def __init(self, a):
                 super().__init__(a) # Super() ohne Parameter aufrufen
>>> D(8)
C 8
<__main__.D Objekt bei 0x00D7ED90>
14) Neue Metaklassensyntax:
Klasse Foo(*bases, **kwds):
Pass
15) Unterstützen Sie den Klassendekorateur. Die Verwendung ist die gleiche wie beim Funktionsdekorator:
>>> def foo(cls_a):
              def print_func(self):
                                                     print('Hello, world!')
            cls_a.print = print_func
            return cls_a
>>> @foo
Klasse C(Objekt):
Pass
>>> C().print()
Hallo Welt!
Mit dem Klassendekorateur lässt sich der Trick spielen, die Zibetkatze in einen Prinzen zu verwandeln. Weitere Informationen finden Sie unter PEP 3129

4. Strings und Byte-Strings 1) Jetzt gibt es nur noch einen String-Typ, str, aber dieser ist fast derselbe wie die 2.x-Version von Unicode.

2) Bezüglich Byte-Strings siehe Punkt 2 von „Datentyp“

5. Datentyp 1) Py3.X hat den Long-Typ entfernt und jetzt gibt es nur noch einen Integer-Typ – int, aber er verhält sich wie 2. 2) Ein neuer Bytetyp wird hinzugefügt, der der Oktettzeichenfolge der Version 2.X entspricht. Die Methode zum Definieren eines Byteliterals ist wie folgt:
>>> b = b'china'
>>> Typ(b)

str-Objekte und bytes-Objekte können mit der Methode .encode() (str -> bytes) oder .decode() (bytes -> str) ineinander konvertiert werden.
>>> s = b.decode()
>>> s
'China'
>>> b1 = s.encode()
>>> b1
b'china'
3) Die Methoden .keys(), .items und .values() von dict geben Iteratoren zurück, während die vorherigen Funktionen iterkeys() und andere aufgegeben wurden. Ebenfalls entfernt wurde
dict.has_key(), ersetzen Sie es durch in

6. Objektorientiert
1) Einführung abstrakter Basisklassen (Abstract Base Classes, ABCs).
2) Containerklassen und Iteratorklassen haben die Größe ABC, daher gibt es im Cellections-Modul viel mehr Typen als in Py2.5.
>>> Sammlungen importieren
>>> print('n'.join(dir(collections)))
Abrufbar
Behälter
Hashbar
Artikelansicht
Iterierbar
Iterator
KeysView
Zuordnung
MappingView
MutableMapping
MutableSequence
MutableSet
NamedTuple
Reihenfolge
Festlegen
Größe
Werteansicht
__alle__
__builtins__
__doc__
__file__
__name__
_abcoll
_itemgetter
_sys
defaultdict
deque
Darüber hinaus haben numerische Typen auch die ABC-Größe. Zu diesen beiden Punkten siehe PEP 3119 und PEP 3141.
3) Die next()-Methode des Iterators wird in __next__() umbenannt und die integrierte Funktion next() wird hinzugefügt, um die __next__()-Methode des Iterators
aufzurufen 4) Zwei Dekoratoren, @abstractmethod und @abstractproperty, wurden hinzugefügt, um das Schreiben abstrakter Methoden (Eigenschaften) bequemer zu machen.

7. Anomalie
1) Alle Ausnahmen werden von BaseException geerbt und StardardError
wird entfernt 2) Das Sequenzverhalten und das .message-Attribut der Ausnahmeklasse entfernt
3) Verwenden Sie „raise Exception(args)“ anstelle der „raise Exception, args“-Syntax
4) Syntaxänderungen zum Abfangen von Ausnahmen; das Schlüsselwort as wird eingeführt, um Ausnahmeinstanzen zu identifizieren, in Py2.5:
>>> Versuchen Sie:
...    NotImplementedError('Error')
auslösen ... außer NotImplementedError, Fehler:

... ... print error.message
...
Fehler
In Py3.0:
>>> Versuchen Sie:
Erhöhen Sie NotImplementedError('Error')
          außer NotImplementedError als Fehler: #Achten Sie darauf als
                                print(str(error))
Fehler
5) Ausnahmekette, da __context__ in Version 3.0a1

nicht implementiert ist 8. Moduländerungen
1) Das cPickle-Modul wurde entfernt und kann durch das Pickle-Modul ersetzt werden. Irgendwann werden wir ein transparentes und effizientes Modul haben.
2) Imageop-Modul
entfernt 3) Audiodev, Bastion, bsddb185, Ausnahmen, Linuxaudiodev, MD5, MimeWriter, Mimify, Popen2,
entfernt Rexec-, Sets-, Sha-, Stringold-, Strop-, Sunaudiodev-, Timing- und xmllib-Module
4) Das bsddb-Modul wurde entfernt (separat veröffentlicht, verfügbar unter http://www.jcea.es/programacion/pybsddb.htm)
5) Neues Modul entfernt
6) Die Funktionen os.tmpnam() und os.tmpfile() werden in das tmpfile-Modul
verschoben 7) Das Tokenize-Modul funktioniert jetzt mit Bytes. Der Haupteinstiegspunkt ist nicht mehr generic_tokens, sondern tokenize.tokenize()

9. Andere
1) xrange() wird in range() umbenannt. Wenn Sie range() verwenden möchten, um eine Liste zu erhalten, müssen Sie es explizit aufrufen:
>>> list(range(10))
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
2) Das Bytes-Objekt kann weder hashen, noch unterstützt es die Methoden b.lower(), b.strip() und b.split(), aber für die beiden letztgenannten können Sie b.strip(b’
verwenden ntr f’) und b.split(b’ ‘), um den gleichen Zweck zu erreichen
3) zip(), map() und filter() geben alle Iteratoren zurück. Und apply(), callable(), coerce(), execfile(), Reduce() und reload
()-Funktionen wurden entfernt

Jetzt können Sie hasattr() verwenden, um callable() zu ersetzen. Die Syntax von hasattr() lautet: hasattr(string, '__name__')

4) string.letters und zugehörige .lowercase und .uppercase werden entfernt, bitte verwenden Sie stattdessen string.ascii_letters
5) Wenn x < y nicht verglichen werden kann, wird eine TypeError-Ausnahme ausgelöst. Version 2.x gibt einen pseudozufälligen booleschen Wert
zurück 6) Die Mitglieder der __getslice__-Reihe werden aufgegeben. a[i:j] wird je nach Kontext in a.__getitem__(slice(I, j)) oder __setitem__ und
konvertiert __delitem__ Anrufe
7) Die Dateiklasse wird in Py2.5 aufgegeben:
>>> Datei

In Py3.X:
>>> Datei
Traceback (letzter Anruf zuletzt):
Datei „“, Zeile 1, in
        Datei
NameError: Name „Datei“ ist nicht definiert

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des Unterschieds zwischen Python3.x und Python2.x. 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