首頁  >  文章  >  後端開發  >  php資料導出如何實現

php資料導出如何實現

php中世界最好的语言
php中世界最好的语言原創
2018-05-18 14:45:222641瀏覽

這次帶給大家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中文網其它相關文章!

建議閱讀:

php命名空間使用詳解

#thinkphp5 migrate資料庫遷移使用詳解

#####thinkphp5 migrate資料庫遷移使用詳解####### ###

以上是php資料導出如何實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn