suchen
HeimBackend-EntwicklungPython-TutorialWie löst man den Python-Fehler „UnicodeDecodeError: ‚ASCII'-Codec kann Byte nicht dekodieren'?

How to Solve Python's

So beheben Sie „UnicodeDecodeError: ‚ASCII‘-Codec kann Byte nicht dekodieren“

tl;dr / Quick Fix

  • Vermeiden unnötige Dekodierung/Kodierung.
  • Gehen Sie nicht von der UTF-8-Kodierung aus Zeichenfolgen.
  • Konvertieren Sie Zeichenfolgen so schnell wie möglich in Unicode-Zeichenfolgen in Ihrem Code.
  • Passen Sie Ihr Gebietsschema an (siehe: Wie löst man UnicodeDecodeError in Python 3.6?).
  • Widerstehen die Versuchung für schnelle Reload-Hacks.

Unicode Zen in Python 2.x

UnicodeDecodeError: 'ascii' codec can't decode byte tritt normalerweise auf, wenn Sie versuchen, einen Python 2.x-String, der Nicht-ASCII-Zeichen enthält, in einen Unicode-String zu konvertieren, ohne die Codierung des ursprünglichen Strings anzugeben.

Unicode-Strings (auch Unicodes genannt) sind ein separater String-Typ in Python, der Unicode-Punktcodes enthält und jeden Unicode-Punkt darstellen kann im gesamten Spektrum. Im Gegensatz dazu enthalten Zeichenfolgen codierten Text in verschiedenen Formaten (z. B. UTF-8, UTF-16, ISO-8895-1).

Die Entwickler des Markdown-Moduls verwenden wahrscheinlich unicode() als Qualitätstor, um den Eingang sicherzustellen Zeichenfolgen sind Unicode. Da sie die Codierung des eingehenden Strings nicht bestimmen können, müssen Sie ihn dekodieren, bevor Sie ihn an Markdown übergeben.

Unicode-Strings können in Ihrem Code mit dem Präfix „u“ deklariert werden:

my_u = u'my ünicôdé strįng'
print(type(my_u)) # <type></type>

Unicode-Strings können auch aus Dateien, Datenbanken oder Netzwerkmodulen entstehen, bei denen Sie das nicht angeben müssen Kodierung.

Problemfälle

Unicode-Konvertierung kann auch ohne explizite unicode()-Aufrufe erfolgen:

# Explicit conversion without encoding
unicode('€')

# New-style format string into Unicode string
# Python attempts to convert value string to Unicode first
u"The currency is: {}".format('€')

# Old-style format string into Unicode string
# Python attempts to convert value string to Unicode first
u'The currency is: %s' % '€'

# Append string to Unicode
# Python attempts to convert string to Unicode first
u'The currency is: ' + '€'

Beispiele

Im folgenden Diagramm „café „ ist je nach Terminaltyp unterschiedlich in „UTF-8“ und „Cp1252“ kodiert. In beiden Fällen wird „caf“ in reinem ASCII codiert. Während UTF-8 zwei Bytes zur Darstellung von „é“ verwendet, verwendet Cp1252 ein einzelnes Byte, das zufällig auch mit dem Unicode-Punktwert übereinstimmt. In diesem Fall wird decode() mit der richtigen Codierung aufgerufen und eine erfolgreiche Konvertierung in Unicode durchgeführt:

[Diagramm einer erfolgreichen Unicode-Konvertierung mit der richtigen Codierung]

Allerdings, wenn decode () mit „ascii“ aufgerufen wird, was dem Aufruf von unicode() ohne Angabe einer Codierung ähnelt, tritt ein UnicodeDecodeError auf:

[Diagramm von eine fehlgeschlagene Unicode-Konvertierung mit der falschen Codierung]

Das Unicode-Sandwich

Es empfiehlt sich, in Ihrem Code ein „Unicode-Sandwich“ zu erstellen, in dem Sie:

  1. Dekodieren Sie alle eingehenden Daten in Unicode-Zeichenfolgen.
  2. Führen Sie Operationen mit Unicode durch Zeichenfolgen.
  3. Auf dem Weg nach draußen in str kodieren.

Dieser Ansatz verhindert, dass Sie sich im gesamten Code um die Zeichenfolgenkodierung kümmern müssen.

Eingabe/Dekodierung

  • Verwenden Sie für Quellcode Unicode-Zeichenfolgenliterale (z. B. u'Zürich') und fügen Sie einen Codierungsheader hinzu (z. B. #-Kodierung: utf-8).
  • Verwenden Sie für Dateien den TextWrapper des io-Moduls mit der entsprechenden Kodierung:

    my_u = u'my ünicôdé strįng'
    print(type(my_u)) # <type></type>
  • Konfigurieren Sie für Datenbanken die Verbindung so, dass sie Unicode-Daten zurückgibt und Unicode-Zeichenfolgen für SQL-Abfragen verwendet.
  • Für HTTP sollten Sie die Verwendung der Python Requests-Bibliothek in Betracht ziehen, die Unicode in „response.text“ zurückgibt .
  • Für die manuelle Dekodierung verwenden Sie my_string.decode(encoding), wobei die Kodierung die geeignete ist value.

Ausgabe

  • stdout/printing: Python versucht, einen Encoder forstdout zu konfigurieren, um Unicode-Strings in die Codierung der Konsole zu codieren. Wenn die Kodierung der Konsole falsch ist, können Fehler auftreten.
  • Dateien: io.open kann Unicode transparent in Byte-Strings kodieren.
  • Datenbanken: Durch die richtige Konfiguration können Sie Unicode-Daten direkt in die Konsole schreiben Datenbank.

Das obige ist der detaillierte Inhalt vonWie löst man den Python-Fehler „UnicodeDecodeError: ‚ASCII'-Codec kann Byte nicht dekodieren'?. 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
Python: Erforschen der primären AnwendungenPython: Erforschen der primären AnwendungenApr 10, 2025 am 09:41 AM

Python wird in den Bereichen Webentwicklung, Datenwissenschaft, maschinelles Lernen, Automatisierung und Skripten häufig verwendet. 1) In der Webentwicklung vereinfachen Django und Flask Frameworks den Entwicklungsprozess. 2) In den Bereichen Datenwissenschaft und maschinelles Lernen bieten Numpy-, Pandas-, Scikit-Learn- und TensorFlow-Bibliotheken eine starke Unterstützung. 3) In Bezug auf Automatisierung und Skript ist Python für Aufgaben wie automatisiertes Test und Systemmanagement geeignet.

Wie viel Python können Sie in 2 Stunden lernen?Wie viel Python können Sie in 2 Stunden lernen?Apr 09, 2025 pm 04:33 PM

Sie können die Grundlagen von Python innerhalb von zwei Stunden lernen. 1. Lernen Sie Variablen und Datentypen, 2. Master -Steuerungsstrukturen wie wenn Aussagen und Schleifen, 3. Verstehen Sie die Definition und Verwendung von Funktionen. Diese werden Ihnen helfen, einfache Python -Programme zu schreiben.

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 ...

Was soll ich tun, wenn das Modul '__builtin__' beim Laden der Gurkendatei in Python 3.6 nicht gefunden wird?Was soll ich tun, wenn das Modul '__builtin__' beim Laden der Gurkendatei in Python 3.6 nicht gefunden wird?Apr 02, 2025 am 07:12 AM

Laden Sie Gurkendateien in Python 3.6 Umgebungsbericht Fehler: ModulenotFoundError: Nomodulennamen ...

Wie verbessert man die Genauigkeit der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse?Wie verbessert man die Genauigkeit der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse?Apr 02, 2025 am 07:09 AM

Wie löste ich das Problem der Jiebeba -Wortsegmentierung in der malerischen Spot -Kommentaranalyse? Wenn wir malerische Spot -Kommentare und -analysen durchführen, verwenden wir häufig das Jieba -Word -Segmentierungstool, um den Text zu verarbeiten ...

Wie benutze ich den regulären Ausdruck, um das erste geschlossene Tag zu entsprechen und anzuhalten?Wie benutze ich den regulären Ausdruck, um das erste geschlossene Tag zu entsprechen und anzuhalten?Apr 02, 2025 am 07:06 AM

Wie benutze ich den regulären Ausdruck, um das erste geschlossene Tag zu entsprechen und anzuhalten? Im Umgang mit HTML oder anderen Markup -Sprachen sind häufig regelmäßige Ausdrücke erforderlich, um ...

Wie bekomme ich Nachrichtendaten, die den Anti-Crawler-Mechanismus von Investing.com umgehen?Wie bekomme ich Nachrichtendaten, die den Anti-Crawler-Mechanismus von Investing.com umgehen?Apr 02, 2025 am 07:03 AM

Verständnis der Anti-Crawling-Strategie von Investing.com Viele Menschen versuchen oft, Nachrichten von Investing.com (https://cn.investing.com/news/latest-news) zu kriechen ...

See all articles

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen