首頁  >  文章  >  後端開發  >  PHP資料匯出知識點詳解

PHP資料匯出知識點詳解

小云云
小云云原創
2018-02-22 10:16:501411瀏覽

最近在做後台管理的項目,後台通常有資料匯出到 excel 的需要,經過之前搜尋通常建議使用的是 php excel ,我常使用的是 laravel ,對於 php excel 也有很好用的對應 package。

開始使用是非常好用的,但是當需要匯出的資料達到上萬條時就直接帶來記憶體不足的問題。

然後我找到了幾個解決方案。

前端解決方案

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 使用可以方便快速匯出全部資料。

相關推薦:

Python如何將資料匯出excel的技巧分享

投機型:如何利用PHP將數據匯出到Excel表中(圖文解說)

php將資料匯出為execl檔案格式

#

以上是PHP資料匯出知識點詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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