ホームページ >バックエンド開発 >PHPチュートリアル >PHPデータエクスポートの実装方法

PHPデータエクスポートの実装方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-18 14:45:222701ブラウズ

今回は、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のchunkと併用することで簡単かつ迅速に全てのデータをエクスポートすることができます。

この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

PHP名前空間の使用法の詳細な説明

thinkphp5の移行データベース移行の使用法の詳細な説明

以上がPHPデータエクスポートの実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。