파일을 두 번 반복: Python의 파일 반복 메커니즘 이해
Python에서 파일을 반복하려면 루프를 사용하여 한 줄씩 읽는 작업이 포함됩니다. 건설하다. 그러나 동일한 파일을 두 번째로 반복하려고 하면 예상치 못한 결과가 발생하는 경우가 많습니다. 즉, 출력이 없습니다.
이 동작은 Python의 기본 파일 반복 메커니즘 때문입니다. 첫 번째 루프를 실행하면
for line in f.readlines(): print(line)
파일을 끝까지 읽습니다. 이는 테이프 플레이어에서 테이프 끝까지 읽는 것과 유사합니다. 끝에 도달하면 더 이상 읽을 데이터가 없습니다.
파일을 다시 반복하려면 파일 포인터를 시작 부분으로 재설정해야 합니다. 이는 두 가지 방법으로 달성할 수 있습니다:
1. f.seek(0) 사용:
f.seek(0) for line in f.readlines(): print(line)
f.seek(0)을 호출하면 파일 포인터를 파일 시작 부분으로 재배치하여 다시 읽을 수 있습니다.
2. 파일을 닫고 다시 열기:
f.close() f = open('baby1990.html', 'rU') for line in f.readlines(): print(line)
파일을 닫았다가 다시 열면 자동으로 파일 포인터가 시작 부분으로 재설정됩니다.
대안: 블록과 함께 사용:
with 문은 보다 편리하고 안전한 작업 방법을 제공합니다. 파일:
with open('baby1990.html', 'rU') as f: for line in f: print(line)
with 블록 내에서는 예외나 루프에 관계없이 블록이 종료되면 파일이 자동으로 닫힙니다. 이렇게 하면 수동으로 파일을 처리할 필요가 없습니다.
위 내용은 Python 파일을 두 번 반복하면 예기치 않은 결과가 생성되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!