PHP 데이터 내보내기를 구현하는 방법

php中世界最好的语言
풀어 주다: 2023-03-26 16:32:02
원래의
2633명이 탐색했습니다.

이번에는 PHP 데이터 내보내기 구현 방법과 PHP 데이터 내보내기 구현 시 주의 사항이 무엇인지 알려드리겠습니다. 다음은 실제 사례입니다.

처음에는 사용하기가 매우 쉽지만 내보내야 할 데이터가 수만 개에 도달하면 메모리 부족 문제가 직접적으로 발생합니다.

그런 다음 몇 가지 해결책을 찾았습니다.

프런트엔드 솔루션

PHP는 SheetJS/js-xlsx와 협력하여 대량의 Excel 데이터를 내보냅니다.

이 솔루션의 장점은 추가 인터페이스가 필요하지 않지만 프런트엔드에 따라 다르다는 것입니다. 개발자.

CSV로 내보내기

이 솔루션은 더 빠르고 완전히 백엔드에서 구현됩니다. 단점은 csv 형식이 내보낸 양식에 대한 요구 사항이 상대적으로 높고 그림과 같은 서식 있는 텍스트 형식을 포함할 수 없다는 것입니다.

다음은 csv 내보내기 방법을 주로 소개합니다

PHP 공식 문서 소개

<?php
$list = array (
  array(&#39;aaa&#39;, &#39;bbb&#39;, &#39;ccc&#39;, &#39;dddd&#39;),
  array(&#39;123&#39;, &#39;456&#39;, &#39;789&#39;),
  array(&#39;"aaa"&#39;, &#39;"bbb"&#39;)
);
$fp = fopen(&#39;file.csv&#39;, &#39;w&#39;);
foreach ($list as $fields) {
  fputcsv($fp, $fields);
}
fclose($fp);
?>
로그인 후 복사

전체 예제 내보내기

<?php
$name = &#39;test&#39;;
header ( "Content-type:application/vnd.ms-excel" );
header ( "Content-Disposition:filename=".$name.".csv" );
header (&#39;Cache-Control: max-age=0&#39;);
//打开PHP文件句柄,php://output 表示直接输出到浏览器
$fp = fopen(&#39;php://output&#39;, &#39;a&#39;);  
// 写入BOM头,防止乱码
fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF)); 
// 生成的测试数据
function test()
{
  for ($i=0; $i < 150000; $i++) {
    yield [&#39;name&#39;, $i, &#39;男&#39;];
  }
}
// 表头
$headers = [&#39;名字&#39;, &#39;年龄&#39;, &#39;性别&#39;];
fputcsv($fp, $headers);
foreach (test() as $value) {
  fputcsv($fp, $value);
}
fclose($fp);
?>
로그인 후 복사

laravel에서 청크와 함께 사용하면 모든 데이터를 쉽고 빠르게 내보낼 수 있습니다.

이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

추천 도서:

PHP 네임스페이스 사용법에 대한 자세한 설명

thinkphp5 마이그레이션 데이터베이스 마이그레이션 사용법에 대한 자세한 설명

위 내용은 PHP 데이터 내보내기를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!