Semasa menulis fail CSV dalam Python pada sistem Windows, isu yang tidak dijangka timbul apabila r tambahan aksara muncul pada penghujung setiap baris dalam fail. Penyimpangan daripada jangkaan penamatan baris rn ini menimbulkan kebimbangan, menyebabkan pembangun tertanya-tanya tentang punca asas dan sama ada ia adalah tingkah laku yang dimaksudkan.
Untuk menyelidiki sumber isu ini, mari kita menganalisis coretan kod yang disediakan:
import csv with open('test.csv', 'w') as outfile: writer = csv.writer(outfile, delimiter=',', quoting=csv.QUOTE_MINIMAL) writer.writerow(['hi', 'dude']) writer.writerow(['hi2', 'dude2'])
Kod ini direka bentuk untuk menjana fail CSV bernama test.csv yang mengandungi dua baris data: ['hi', 'dude'] dan ['hi2', 'dude2']. Walau bagaimanapun, selepas memeriksa fail yang dijana, kami mendapati bahawa setiap baris diakhiri dengan aksara r tambahan.
Untuk memahami tingkah laku ini, kami beralih kepada dokumentasi Python untuk modul csv. Menurut dokumentasi, adalah disyorkan untuk membuka fail dengan newline='' pada semua platform untuk melumpuhkan terjemahan baris baharu universal.
Untuk Python 3:
Secara lalai , pada Windows, modul csv menggunakan terjemahan baris baharu universal, yang menterjemahkan penamat baris rn kepada n apabila menulis pada fail. Untuk menghalang terjemahan ini dan mengekalkan penamat baris rn asal, ia perlu membuka fail dengan newline='', seperti yang ditunjukkan di bawah:
with open('output.csv', 'w', newline='', encoding='utf-8') as f: writer = csv.writer(f) ...
Untuk Python 2:
Pada Windows untuk Python 2, adalah penting untuk membuka fail dalam mod binari, menggunakan 'rb' atau 'wb', sebelum menghantarnya ke salah satu csv.reader atau csv.writer. Walaupun fail itu adalah fail teks, CSV dianggap sebagai format binari oleh perpustakaan yang terlibat, dengan rn memisahkan rekod. Menulis pemisah ini dalam mod teks menggesa masa jalan Python untuk menggantikan n dengan rn, menghasilkan urutan rrn yang diperhatikan dalam fail. Rujuk jawapan sebelum ini untuk butiran lanjut tentang aspek ini.
Atas ialah kandungan terperinci Mengapa Fail CSV Python Saya Menambah Pulangan Pengangkutan Tambahan pada Windows?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!