> 백엔드 개발 > 파이썬 튜토리얼 > Windows에서 내 Python CSV 출력에 추가 캐리지 리턴이 있는 이유는 무엇입니까?

Windows에서 내 Python CSV 출력에 추가 캐리지 리턴이 있는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-03 19:30:13
원래의
479명이 탐색했습니다.

Why Does My Python CSV Output Have Extra Carriage Returns on Windows?

Python에서 Windows의 CSV 출력 파일 추가 캐리지 리턴 문제

Python에서 CSV 파일을 생성할 때 실수로 캐리지를 추가할 수 있습니다. 각 행의 끝에서 반환됩니다. 이 동작은 다음 코드에서 관찰할 수 있습니다.

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'])
로그인 후 복사

예상 출력:

hi,dude
hi2,dude2
로그인 후 복사

실제 출력(Windows):

hi,dude\r\r\nhi2,dude2\r\r\n
로그인 후 복사

원인 및 Python 3의 해결 방법:

Python 3에서는 다음과 같습니다. 기본 범용 개행 번역 기능으로 인해 문제가 발생합니다. 이 문제를 해결하려면 newline=''으로 파일을 열어 이 번역을 비활성화하세요.

with open('output.csv', 'w', newline='', encoding='utf-8') as f:
    writer = csv.writer(f)
    ...
로그인 후 복사

Python 2의 원인 및 해결 방법:

Windows의 Python 2 , 이 문제는 CSV가 이진 형식으로 간주되고 rn이 레코드 구분 기호이기 때문에 발생합니다. 파일이 텍스트 모드로 열리면 Python은 n을 rn으로 대체하여 이중 캐리지 리턴이 발생합니다. 해결책은 항상 바이너리 모드로 파일을 여는 것입니다.

with open('test.csv', 'wb') as outfile:
    writer = csv.writer(outfile, delimiter=',', quoting=csv.QUOTE_MINIMAL)
    ...
로그인 후 복사

위 내용은 Windows에서 내 Python CSV 출력에 추가 캐리지 리턴이 있는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿