Heim Backend-Entwicklung Python-Tutorial Python löst das Problem der Kodierung chinesischer Zeichen: Unicode Decode Error_python

Python löst das Problem der Kodierung chinesischer Zeichen: Unicode Decode Error_python

Feb 23, 2017 pm 03:53 PM

Vorwort

Vor kurzem musste ich aufgrund von Projektanforderungen ein TXT-Dokument mit Chinesisch lesen und die Datei dann speichern. Das Dokument wurde zuvor mit base64 codiert, wodurch alle chinesischen Zeichen gelesen und als verstümmelte Zeichen angezeigt wurden. Nachdem das Projektteam base64 aufgegeben hatte, traten nacheinander zwei Fehler auf:

ascii codec can't encode characters in position ordinal not in range 128
UnicodeDecodeError: ‘utf8' codec can't decode byte 0x。
Nach dem Login kopieren

Wenn Sie sich nicht mit ASCII, Unicode und UTF-8 auskennen, können Sie dies tun Lesen Sie diesen vorherigen Artikel über Zeichenfolgen und Codierung

Dann müssen Sie die folgenden drei Konzepte verstehen:

  1. nur ASCII Kann Zahlen, englische Buchstaben und darstellen einige Sonderzeichen, können aber keine chinesischen Schriftzeichen darstellen

  2. Sowohl Unicode als auch UTF-8 können chinesische Schriftzeichen darstellen, Unicode hat eine feste Länge und UTF-8 hat eine variable Länge

  3. Die Speicherspeichermethode ist im Allgemeinen Unicode, während die Speichermethode für Festplattendateien im Allgemeinen UTF-8 ist, da UTF-8 Speicherplatz sparen kann

Was ist also die Standardcodierung von Python?

>>> import sys
>>> sys.getdefaultencoding()
'ascii'
>>> reload(sys)
<module &#39;sys&#39; (built-in)>
>>> sys.setdefaultencoding(&#39;utf-8&#39;)
>>> sys.getdefaultencoding()
&#39;utf-8&#39;
Nach dem Login kopieren

Die Standardkodierung von Python ist ASCII, und Sie können die Standardkodierung von Python über die Funktion sys.setdefaultencoding(&#39;utf-8&#39;) festlegen.

In Python können Sie die Kodierung von Daten durch Kodieren und Dekodieren ändern, zum Beispiel:

>>> u&#39;汉字&#39;
u&#39;\u6c49\u5b57&#39;
>>> u&#39;汉字&#39;.encode(&#39;utf-8&#39;)
&#39;\xe6\xb1\x89\xe5\xad\x97&#39;
>>> u&#39;汉字&#39;.encode(&#39;utf-8&#39;).decode(&#39;utf-8&#39;)
u&#39;\u6c49\u5b57&#39;
Nach dem Login kopieren

Wir können diese beiden verwenden Funktionen Kodierung festlegen.

Also, welcher Typ ist str in Python?

>>> import binascii
>>> &#39;汉字&#39;
&#39;\xba\xba\xd7\xd6&#39;
>>> type(&#39;汉字&#39;)
<type &#39;str&#39;>
>>> print binascii.b2a_hex(&#39;汉字&#39;)
babad7d6
>>> print binascii.b2a_hex(u&#39;汉字&#39;)
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
UnicodeEncodeError: &#39;ascii&#39; codec can&#39;t encode characters in
position 0-1: ordinal not in range(128)
>>> print binascii.b2a_hex(u&#39;汉字&#39;.encode(&#39;utf-8&#39;))
e6b189e5ad97
>>> print binascii.b2a_hex(u&#39;汉字&#39;.encode(&#39;gbk&#39;))
babad7d6
Nach dem Login kopieren

binascii konvertiert die Binärdaten in ASCII. Die obige Erklärung lautet: Der Typ der „chinesischen Zeichen“ ist str, und die binär ist babad7d6 , u'Chinesisches Zeichen' kann nicht in ASCII konvertiert werden, daher wird der erste Fehler am Anfang gemeldet. Die Lösung besteht darin, es in den Typ str zu kodieren('utf-8'). Da meine Befehlszeile die Standard-GBK-Codierung von Windows verwendet, sind die Ausgabeergebnisse, wenn alle „chinesischen Zeichen“.encode(‘gbk&#39;) erscheinen, mit den Ergebnissen für „chinesische Zeichen“ identisch.

Zusammenfassend lässt sich sagen, dass Pythons Str tatsächlich eine Art Unicode ist. Bei der Konvertierung von Nicht-ASCII in ASCII wird ein Fehler gemeldet:

  1. unicode => encode('geeignete Kodierung') => str

  2. str => dekodieren('geeignete Kodierung') => Unicode

Es gibt auch eine einfache Möglichkeit, nämlich die Kodierung im Dateiheader festzulegen, was viel Ärger ersparen kann:

import sys
reloads(sys)
sys.setdefaultencoding(&#39;utf-8&#39;)
Nach dem Login kopieren

Beim zweiten Problem ist beim Lesen der Datei ein Fehler aufgetreten. UTF-8-Dateien haben zwei Modi: BOM und kein BOM. Der Unterschied zwischen den beiden scheint darin zu bestehen, dass die BOM-Datei einen Header mehr hat als die BOM-lose Datei, was beim Lesen der Datei im UTF-8-Modus zu einem Fehler führt Ich habe vorher versucht, die Datei zu lesen. Zuerst zu beurteilen, ob eine Stückliste vorhanden ist, und den Header der Stücklistendatei zu überspringen. Dann war es wirklich peinlich.

Sie müssen sich an Google wenden, um Hilfe zu erhalten. Die spezifische Vorgehensweise besteht darin, die Codecs-Bibliothek zum Lesen der Datei zu verwenden (ich vermute, diese Bibliothek dient dazu, den Header der Datei zu erkennen).

import codecs
codecs.open(file_name, "r",encoding=&#39;utf-8&#39;, errors=&#39;ignore&#39;)
Nach dem Login kopieren

Bei Codierungsproblemen müssen Sie die Funktionsprinzipien von ASCII, Unicode und UTF-8 verstehen.

Weitere Python-Lösungen für Probleme mit der Codierung chinesischer Zeichen: Artikel zu Unicode Decode Error_python finden Sie auf der chinesischen PHP-Website!

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)

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer-Anfänger-Programmierbasis in Projekt- und problemorientierten Methoden? Apr 02, 2025 am 07:18 AM

Wie lehre ich innerhalb von 10 Stunden die Grundlagen für Computer -Anfänger für Programmierungen? Wenn Sie nur 10 Stunden Zeit haben, um Computer -Anfänger zu unterrichten, was Sie mit Programmierkenntnissen unterrichten möchten, was würden Sie dann beibringen ...

Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Wie kann man vom Browser vermeiden, wenn man überall Fiddler für das Lesen des Menschen in der Mitte verwendet? Apr 02, 2025 am 07:15 AM

Wie kann man nicht erkannt werden, wenn Sie Fiddlereverywhere für Man-in-the-Middle-Lesungen verwenden, wenn Sie FiddLereverywhere verwenden ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Apr 01, 2025 pm 10:51 PM

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Apr 01, 2025 pm 11:18 PM

Wie erstellt in Python ein Objekt dynamisch über eine Zeichenfolge und ruft seine Methoden auf? Dies ist eine häufige Programmieranforderung, insbesondere wenn sie konfiguriert oder ausgeführt werden muss ...

Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Wie löste ich Berechtigungsprobleme bei der Verwendung von Python -Verssionsbefehl im Linux Terminal? Apr 02, 2025 am 06:36 AM

Verwenden Sie Python im Linux -Terminal ...

See all articles