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 중국어 웹사이트의 기타 관련 기사를 참조하세요!