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

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

Patricia Arquette
풀어 주다: 2024-12-06 04:19:09
원래의
796명이 탐색했습니다.

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

파일을 두 번 반복: Python의 파일 반복 메커니즘 이해

Python에서 파일을 반복하려면 루프를 사용하여 한 줄씩 읽는 작업이 포함됩니다. 건설하다. 그러나 동일한 파일을 두 번째로 반복하려고 하면 예상치 못한 결과가 발생하는 경우가 많습니다. 즉, 출력이 없습니다.

이 동작은 Python의 기본 파일 반복 메커니즘 때문입니다. 첫 번째 루프를 실행하면

1

2

for line in f.readlines():

    print(line)

로그인 후 복사

파일을 끝까지 읽습니다. 이는 테이프 플레이어에서 테이프 끝까지 읽는 것과 유사합니다. 끝에 도달하면 더 이상 읽을 데이터가 없습니다.

파일을 다시 반복하려면 파일 포인터를 시작 부분으로 재설정해야 합니다. 이는 두 가지 방법으로 달성할 수 있습니다:

1. f.seek(0) 사용:

1

2

3

f.seek(0)

for line in f.readlines():

    print(line)

로그인 후 복사

f.seek(0)을 호출하면 파일 포인터를 파일 시작 부분으로 재배치하여 다시 읽을 수 있습니다.

2. 파일을 닫고 다시 열기:

1

2

3

4

f.close()

f = open('baby1990.html', 'rU')

for line in f.readlines():

    print(line)

로그인 후 복사

파일을 닫았다가 다시 열면 자동으로 파일 포인터가 시작 부분으로 재설정됩니다.

대안: 블록과 함께 사용:

with 문은 보다 편리하고 안전한 작업 방법을 제공합니다. 파일:

1

2

3

with open('baby1990.html', 'rU') as f:

    for line in f:

        print(line)

로그인 후 복사

with 블록 내에서는 예외나 루프에 관계없이 블록이 종료되면 파일이 자동으로 닫힙니다. 이렇게 하면 수동으로 파일을 처리할 필요가 없습니다.

위 내용은 Python 파일을 두 번 반복하면 예기치 않은 결과가 생성되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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