Python의
제공된 코드 조각은 예상치 못한 추가 캐리지 리턴이 있는 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) # ...
기본적으로 CSV 작성기는 RFC 4180에 따라 각 줄을 'rn'으로 끝냅니다.
Windows에서는 파일을 바이너리 모드로 열어야 합니다. ("rb" 또는 "wb")을 csv.reader 또는 csv.writer에 전달하기 전에 확인하세요. CSV는 텍스트 형식이지만 관련 라이브러리에서는 레코드를 구분하는 'rn'을 사용하여 바이너리로 간주합니다. 텍스트 모드로 작성하면 Python 런타임이 'n'을 'rn'으로 대체하여 추가 캐리지 리턴이 발생합니다.
위 내용은 내 Python CSV 작성기가 Windows에서 추가 캐리지 리턴을 추가하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!