PHPExcel 메모리 과부하
PHPExcel은 메모리 소모량이 많은 것으로 악명 높으며, 이로 인해 로드를 시도할 때 메모리 부족 오류가 자주 발생합니다. 대용량 엑셀 파일. 이는 특히 더 작은 덩어리로 쉽게 분할할 수 없는 파일을 작업할 때 큰 불편을 초래할 수 있습니다.
문제 이해
PHPExcel 메모리 소비의 주요 동인은 다음과 같습니다. 스프레드시트의 메모리 내 표현입니다. 이 표현에는 해당 값, 형식 및 기타 속성을 포함하여 각 셀에 대한 데이터가 포함됩니다. 셀 수가 많은 대형 스프레드시트의 경우 이 표현은 PHP 프로세스에 할당된 사용 가능한 메모리를 빠르게 초과할 수 있습니다.
가능한 솔루션
메모리 문제를 완화하려면 다음 전략을 고려하세요. :
1. 특정 워크시트 또는 범위 로드:
작업에 스프레드시트의 일부만 필요한 경우 setLoadSheetsOnly() 또는 setReadFilter() 메서드를 사용하여 해당 특정 영역에 집중하세요. 이렇게 하면 메모리 사용량이 크게 줄어듭니다.
2. ReadDataOnly 설정:
setReadDataOnly(true)를 설정하면 PHPExcel이 셀 서식을 로드하지 못하게 하여 값 전용 데이터 검색을 위한 메모리 소비를 줄입니다.
3. 청크 처리:
스프레드시트가 더 작은 세그먼트에 로드되는 "청크 처리" 접근 방식을 구현합니다. 이를 통해 사용 가능한 메모리 제한 내에서 각 청크를 처리하고 나중에 해제할 수 있습니다.
4. 셀 캐싱:
셀 캐싱을 활성화하여 셀 개체를 압축 형식으로 저장하거나 PHP 메모리 외부에 저장합니다. 이렇게 하면 셀 메모리 오버헤드가 크게 줄어들지만 처리 속도에 영향을 줄 수 있습니다.
5. RangetoArray() 메서드 활용:
rangeToArray() 메서드는 행 데이터의 연관 배열을 구축하여 반복자 및 수동 배열 구성에 비해 효율성이 향상됩니다.
유용한 코드 예
// Limit to specific worksheets $objReader->setLoadSheetsOnly($sheetname); // Implement read filter $filterSubset = new MyReadFilter(); $objReader->setReadFilter($filterSubset); // Read data only $objReader->setReadDataOnly(true); // Use rangeToArray() method $arrayData = $objPHPExcel->getActiveSheet()->rangeToArray('A1:E7');
이러한 기술을 신중하게 구현하면 다음을 효과적으로 수행할 수 있습니다. PHPExcel 사용을 최적화하고 대용량 Excel 파일을 로드하는 동안 메모리 부족 오류를 완화합니다.
위 내용은 대용량 Excel 파일을 처리할 때 PHPExcel 메모리 과부하를 어떻게 방지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!