Heim >Backend-Entwicklung >Python-Tutorial >Warum fügt mein Python-CSV-Writer unter Windows zusätzliche Wagenrückläufe hinzu?
Der bereitgestellte Codeausschnitt generiert eine CSV-Datei mit einem unerwarteten zusätzlichen Wagenrücklauf (r) in jeder Zeile. Anstelle der gewünschten Ausgabe:
hi,dude hi2,dude2
Die Datei lautet wie folgt:
hi,dude\r \r hi2,dude2\r \r
Dieses Verhalten entsteht aufgrund der plattformspezifischen Leitungsterminierungsbehandlung.
Die offizielle CSV-Dokumentation empfiehlt die Verwendung von „newline=''“ beim Öffnen von Dateien Deaktivieren Sie die universelle Zeilenumbruchübersetzung:
with open('output.csv', 'w', newline='', encoding='utf-8') as f: writer = csv.writer(f) # ...
Standardmäßig beendet der CSV-Writer jede Zeile mit „rn“, gemäß RFC 4180.
Unter Windows sollten Dateien im Binärmodus („rb“ oder „wb“) geöffnet werden, bevor sie an übergeben werden csv.reader oder csv.writer. Obwohl CSV ein Textformat ist, wird es von den beteiligten Bibliotheken als binär betrachtet, wobei „rn“ Datensätze trennt. Beim Schreiben im Textmodus ersetzt die Python-Laufzeitumgebung „n“ durch „rn“, was zu den beobachteten zusätzlichen Wagenrückläufen führt.
Das obige ist der detaillierte Inhalt vonWarum fügt mein Python-CSV-Writer unter Windows zusätzliche Wagenrückläufe hinzu?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!