提供的程式碼片段產生一個帶有意外回車符的CSV 檔案(r) 每行。而不是所需的輸出:
hi,dude hi2,dude2
檔案讀取為:
hi,dude\r \r hi2,dude2\r \r
此行為是由於平台特定的行終止處理而出現的。
官方CSV 文件建議在以下情況下使用newline=''開啟檔案以停用通用換行符翻譯:
with open('output.csv', 'w', newline='', encoding='utf-8') as f: writer = csv.writer(f) # ...
預設情況下,根據RFC 4180,CSV 編寫器以「rn」終止每一行。
在Windows 上,檔案應以二進位模式開啟(「rb」或「wb」),然後將它們傳遞給csv.reader 或csv.writer。儘管 CSV 是一種文字格式,但相關函式庫將其視為二進位格式,並以“rn”分隔記錄。當以文字模式編寫時,Python 運行時會將 'n' 替換為 'rn',導致觀察到額外的回車符。
以上是為什麼我的 Python CSV 編寫器在 Windows 上添加額外的回車符號?的詳細內容。更多資訊請關注PHP中文網其他相關文章!