


Python-Lösen Sie das Problem von UnicodeDecodeError beim Abfragen von Cx_Oracle
In einem aktuellen Projekt musste ich eine Tabelle mit mehr als 1 Million Datensätzen abfragen und dann einige Datenstatistiken durchführen. Während dieses Vorgangs stellte ich jedoch fest, dass ein UnicodeDecodeError auftrat, nachdem nur wenige Daten abgefragt wurden.
Hier verwenden wir die sqlalchemy-Bibliothek für Abfragen und Cx_Oracle wird intern verwendet, um entsprechende Vorgänge auszuführen. Die verwendete Python-Version ist 3.5.0, das Hostsystem ist Windows 2008 Server, und dann werden Vorgänge ähnlich den folgenden ausgeführt:
from sqlalchemy import create_engine engine = create_engine('oracle://demo:123456@192.168.1.202/TEST') conn = engine.connect() sql = 'select t.type from TS t' result = conn.execute(sql) for row in result: print(row['type'])
Hier stellen wir zunächst eine Verbindung zur Datenbank her und führen dann den entsprechenden Abfragevorgang durch. Leider ist nach der Abfrage von weniger als 10 Datensätzen ein UnicodeDecodeError aufgetreten.
Ursprünglich dachte ich, es handele sich um ein Server-Kodierungsproblem in der Datenbank, also habe ich den Kodierungsparameter zur Funktion „create_engine“ hinzugefügt und ihn geändert in:
engine = create_engine('oracle://demo:123456@192.168.1.202/TEST',encoding="UTF-8")
Die andere verfügbare Methode besteht darin, die Kodierung direkt anzugeben im Verbindungspfad, ähnlich wie folgt:
engine = create_engine('oracle://demo:123456@192.168.1.202/TEST?charset=utf-8')
Aber das Problem ist immer noch nicht gelöst. Ich habe im Internet gesucht, aber keine passende Lösung gefunden. Mir fiel plötzlich ein, dass wir bei der Verwendung einer MySQL-Datenbank (ich persönlich mag Postgresql mehr) oft die folgenden Vorgänge ausgeführt haben, wenn verstümmelte Zeichen auftraten:
set names gbk;
Wir haben die clientseitige Codierung auf diese Weise anstelle der serverseitigen Codierung festgelegt, um das Problem verstümmelter Zeichen auf dem Terminal zu lösen (da die Standarddatenbank von Postgresql UTF-8 ist, ist die Wahrscheinlichkeit verstümmelter Zeichen gering). Darüber hinaus wird bei der Installation des Oracle-Clients unter Linux eine Umgebungsvariable von NLS_LANG
festgelegt. Weitere Informationen finden Sie im Artikel „Oracle Instant Client in Ubuntu 14.04 installieren“. Natürlich werden in diesem Artikel einige Details nicht vorgestellt.
Im Allgemeinen nehmen wir die folgenden Einstellungen in cmd vor:
setenv NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK
Wir geben an, dass die von Oracle-Nachrichten verwendete Sprache vereinfachtes Chinesisch ist und der Zeichensatz des Clients GBK ist.
Darüber hinaus können wir auch die folgende Anweisung ausführen, um sicherzustellen, dass der obige Vorgang korrekt ist:
SELECT * FROM v$nls_parameters;
Da der obige Datenbankserver unter Windows bereitgestellt wird, ist das Ergebnis natürlich GBK, also wenn Our Der Client verwendet zum Dekodieren den UTF8-Zeichensatz, daher treten natürlicherweise Dekodierungsfehler auf.
Was wir beachten müssen, ist, dass wir die Nicht-ASCII-Codierung nur dann normal anzeigen können, wenn die Codierung des Datenbankservers und des Clients konsistent ist, und in sqlalchemy wird die Abfragezeichenfolge standardmäßig gezwungen, sie in Unicode zu konvertieren. Daher ähnelt es dem folgenden Prozess in Python3:
>>> a='中国'.encode('gbk') >>> a b'\xd6\xd0\xb9\xfa'
In sqlalchemy ähnelt es aufgrund der erzwungenen Kodierungskonvertierung dem folgenden Prozess:
>>> a.decode('utf-8') Traceback (most recent call last): File "<stdin>", line 1, in <module> UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd6 in position 0: invalid continuation byte
Daher das obige Problem tritt auf. Unter normalen Umständen sollte die Kodierung als GBK angegeben werden:
>>> a.decode('gbk') '中国'
und die Einstellung NLS_LANG
entspricht der Änderung der oben genannten Kodierung in GBK.
Weitere Informationen zur Python-Lösung des UnicodeDecodeError-Problems beim Abfragen von Cx_Oracle finden Sie auf der chinesischen PHP-Website für verwandte Artikel!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die Geschwindigkeit der mobilen XML zu PDF hängt von den folgenden Faktoren ab: der Komplexität der XML -Struktur. Konvertierungsmethode für mobile Hardware-Konfiguration (Bibliothek, Algorithmus) -Codierungsoptimierungsmethoden (effiziente Bibliotheken, Optimierung von Algorithmen, Cache-Daten und Nutzung von Multi-Threading). Insgesamt gibt es keine absolute Antwort und es muss gemäß der spezifischen Situation optimiert werden.

Mit einer einzigen Anwendung ist es unmöglich, XML -zu -PDF -Konvertierung direkt auf Ihrem Telefon zu vervollständigen. Es ist erforderlich, Cloud -Dienste zu verwenden, die in zwei Schritten erreicht werden können: 1. XML in PDF in der Cloud, 2. Zugriff auf die konvertierte PDF -Datei auf dem Mobiltelefon konvertieren oder herunterladen.

Es gibt keine integrierte Summenfunktion in der C-Sprache, daher muss sie selbst geschrieben werden. Die Summe kann erreicht werden, indem das Array durchquert und Elemente akkumulieren: Schleifenversion: Die Summe wird für die Schleifen- und Arraylänge berechnet. Zeigerversion: Verwenden Sie Zeiger, um auf Array-Elemente zu verweisen, und eine effiziente Summierung wird durch Selbststillstandszeiger erzielt. Dynamisch Array -Array -Version zuweisen: Zuordnen Sie Arrays dynamisch und verwalten Sie selbst den Speicher selbst, um sicherzustellen, dass der zugewiesene Speicher befreit wird, um Speicherlecks zu verhindern.

Es gibt keine App, die alle XML -Dateien in PDFs umwandeln kann, da die XML -Struktur flexibel und vielfältig ist. Der Kern von XML zu PDF besteht darin, die Datenstruktur in ein Seitenlayout umzuwandeln, für das XML analysiert und PDF generiert werden muss. Zu den allgemeinen Methoden gehören das Parsen von XML mithilfe von Python -Bibliotheken wie ElementTree und das Generieren von PDFs unter Verwendung der ReportLab -Bibliothek. Für komplexe XML kann es erforderlich sein, XSLT -Transformationsstrukturen zu verwenden. Wenn Sie die Leistung optimieren, sollten Sie Multithread- oder Multiprozesse verwenden und die entsprechende Bibliothek auswählen.

Es ist nicht einfach, XML direkt auf Ihr Telefon in PDF umzuwandeln, kann jedoch mit Hilfe von Cloud -Diensten erreicht werden. Es wird empfohlen, eine leichte mobile App zu verwenden, um XML -Dateien hochzuladen und generierte PDFs zu empfangen und sie mit Cloud -APIs zu konvertieren. Cloud -APIs verwenden serverlose Computerdienste, und die Auswahl der richtigen Plattform ist entscheidend. Bei der Behandlung von XML -Parsen und PDF -Generation müssen Komplexität, Fehlerbehebung, Sicherheit und Optimierungsstrategien berücksichtigt werden. Der gesamte Prozess erfordert, dass die Front-End-App und die Back-End-API zusammenarbeiten, und es erfordert ein gewisses Verständnis einer Vielzahl von Technologien.

XML kann mithilfe eines XSLT -Konverters oder einer Bildbibliothek in Bilder konvertiert werden. XSLT -Konverter: Verwenden Sie einen XSLT -Prozessor und Stylesheet, um XML in Bilder zu konvertieren. Bildbibliothek: Verwenden Sie Bibliotheken wie Pil oder Imagemagick, um Bilder aus XML -Daten zu erstellen, z. B. Zeichnen von Formen und Text.

Konvertieren Sie XML in PDF mit hoher Qualität auf Ihrem Mobiltelefon müssen: XML in der Cloud analysieren und PDFs mithilfe einer serverlosen Computerplattform generieren. Wählen Sie eine effiziente Bibliothek für XML -Parser- und PDF -Generation. Fehler korrekt behandeln. Nutzen Sie die Cloud -Computing -Leistung voll, um schwere Aufgaben auf Ihrem Telefon zu vermeiden. Passen Sie die Komplexität gemäß den Anforderungen an, einschließlich der Verarbeitung komplexer XML-Strukturen, der Erzeugung von mehrseitigen PDFs und dem Hinzufügen von Bildern. Drucken Sie Protokollinformationen zum Debuggen. Optimieren Sie die Leistung, wählen Sie effiziente Parser- und PDF -Bibliotheken aus und können asynchrone Programmier- oder Vorverarbeitungs -XML -Daten verwenden. Gewährleisten Sie eine gute Codequalität und -wartbarkeit.

Das Konvertieren von XML in PDF direkt auf Android-Telefonen kann durch die integrierten Funktionen nicht erreicht werden. Sie müssen das Land in den folgenden Schritten speichern: XML -Daten in Formate konvertieren, die vom PDF -Generator (z. B. Text oder HTML) erkannt wurden. Konvertieren Sie HTML mithilfe von HTML -Generationsbibliotheken wie Flying Saucer in PDF.
