최근 백엔드 관리 프로젝트를 진행하고 있는데, 보통 백엔드에서 엑셀로 내보내기를 해야 하는 경우가 있는데, 이전에 검색해본 결과 laravel을 자주 사용하는 것을 추천합니다. PHP 엑셀용 패키지입니다.
처음에는 사용하기가 매우 쉽지만 내보내야 할 데이터가 수만 개에 도달하면 메모리 부족 문제가 직접적으로 발생합니다.
그런 다음 몇 가지 해결책을 찾았습니다.
프런트 엔드 솔루션
PHP는 SheetJS/js-xlsx와 협력하여 대량의 Excel 데이터를 내보냅니다.
이 솔루션의 장점은 추가 인터페이스가 필요하지 않지만 프런트 엔드에 따라 다릅니다. -최종 개발자.
CSV로 내보내기
이 솔루션은 더 빠르고 완전히 백엔드에서 구현됩니다. 단점은 csv 형식이 내보낸 양식에 대해 상대적으로 높은 요구 사항을 가지며 그림과 같은 서식 있는 텍스트 형식을 포함할 수 없다는 것입니다. .
다음은 csv 내보내기 방법을 주로 소개합니다
PHP 공식 문서 소개
<?php $list = array ( array('aaa', 'bbb', 'ccc', 'dddd'), array('123', '456', '789'), array('"aaa"', '"bbb"') ); $fp = fopen('file.csv', 'w'); foreach ($list as $fields) { fputcsv($fp, $fields); } fclose($fp); ?>
완전한 예제 내보내기
<?php $name = 'test'; header ( "Content-type:application/vnd.ms-excel" ); header ( "Content-Disposition:filename=".$name.".csv" ); header ('Cache-Control: max-age=0'); //打开PHP文件句柄,php://output 表示直接输出到浏览器 $fp = fopen('php://output', 'a'); // 写入BOM头,防止乱码 fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF)); // 生成的测试数据 function test() { for ($i=0; $i < 150000; $i++) { yield ['name', $i, '男']; } } // 表头 $headers = ['名字', '年龄', '性别']; fputcsv($fp, $headers); foreach (test() as $value) { fputcsv($fp, $value); } fclose($fp); ?>
laravel에서 Chunk를 사용하면 쉽고 빠르게 모든 데이터를 내보낼 수 있습니다.
관련 권장 사항:
Python을 사용하여 Excel로 데이터를 내보내는 방법에 대한 팁
추측: PHP를 사용하여 Excel 테이블로 데이터를 내보내는 방법(그림 설명)
위 내용은 PHP 데이터 내보내기 지식 포인트에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!