>백엔드 개발 >PHP 튜토리얼 >메모리 부족 없이 대용량 Excel 파일을 PHPExcel에 효율적으로 로드하려면 어떻게 해야 합니까?

메모리 부족 없이 대용량 Excel 파일을 PHPExcel에 효율적으로 로드하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-24 06:53:19636검색

How Can I Efficiently Load Large Excel Files into PHPExcel Without Running Out of Memory?

PHPExcel 메모리 부족 문제

PHPExcel을 사용하여 대규모 Excel 테이블을 로드하면 넉넉한 메모리 할당을 허용하더라도 메모리가 고갈될 수 있습니다. 이 문제를 해결하려면 메모리 할당 프로세스를 이해하는 것이 중요합니다.

메모리 소비에 영향을 미치는 요소

PHPExcel의 메모리 요구 사항은 주로 로드된 워크시트의 셀 수에 따라 달라집니다. . 평균 메모리 사용량은 셀당 약 1,000개입니다. 따라서 5M 셀이 포함된 통합 문서에는 약 5GB의 메모리가 필요합니다.

최적화

메모리 소비를 줄이기 위해 몇 가지 최적화를 구현할 수 있습니다.

  • 로드된 워크시트 제한: 특정 워크시트만 로드 setLoadSheetsOnly() 사용.
  • 읽기 필터: 필요한 셀만 선택하려면 읽기 필터를 구현합니다.
  • 청크로 읽기: 통합 문서 로드 한 번에 설정된 수의 행만 메모리에 유지하기 위해 반복합니다. time.
  • 데이터 읽기 전용: setReadDataOnly(true)를 사용하여 형식 지정 없이 셀 값만 로드합니다.
  • 셀 캐싱: 셀을 메모리를 줄이기 위해 압축 형식 또는 PHP 메모리 외부

추가 팁

코드에서 $arrayData 배열은 데이터를 축적하여 잠재적으로 메모리 사용량을 악화시킵니다. 대신 중간 배열 없이도 데이터의 연관 배열을 생성할 수 있는 PHPExcel의 toArray() 메서드나 새로운 rangeToArray() 메서드를 활용해 보세요.

위 내용은 메모리 부족 없이 대용량 Excel 파일을 PHPExcel에 효율적으로 로드하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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