대용량 텍스트 파일을 한 줄씩 효율적으로 읽기: 메모리를 고려한 접근 방식
당면 작업에는 전체 콘텐츠를 한 번에 로드하여 메모리 리소스에 부담을 주지 않고 5GB. 이를 달성하기 위해 과도한 메모리 사용 없이 한 줄씩 읽을 수 있는 대체 접근 방식을 사용할 수 있습니다.
해결책: 한 줄씩 파일 읽기
메모리에 큰 목록을 생성하는 readlines() 함수를 사용하는 대신 for 루프를 사용하여 파일 객체를 반복할 수 있습니다. 이 접근 방식을 사용하면 전체 파일의 메모리 내 표현 생성을 방지하여 상당한 양의 메모리를 소비하지 않고 파일을 처리할 수 있습니다.
Context Manager를 사용한 구현
효율적 자원 관리를 위해서는 open()과 함께 컨텍스트 관리자를 사용하는 것이 좋습니다. with 문 안에 파일 객체를 래핑함으로써 처리 중에 예외가 발생하더라도 읽은 후 파일이 올바르게 닫히도록 보장합니다.
with open("log.txt") as infile: for line in infile: print(line)
이 코드 조각은 "log.txt" 파일을 엽니다. 컨텍스트 관리자를 사용합니다. 그런 다음 for 루프는 파일을 한 줄씩 반복하고 각 줄에 대해 콘솔에 인쇄하는 등 원하는 작업을 수행합니다.
이 접근 방식의 장점:
위 내용은 메모리 제한을 초과하지 않고 대용량 텍스트 파일을 한 줄씩 효율적으로 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!