>백엔드 개발 >파이썬 튜토리얼 >Python 파일을 두 번 반복하면 예기치 않은 결과가 생성되는 이유는 무엇입니까?

Python 파일을 두 번 반복하면 예기치 않은 결과가 생성되는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-06 04:19:09786검색

Why Does Iterating Over a Python File Twice Produce Unexpected Results?

파일을 두 번 반복: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.