php資料匯出詳解

小云云
發布: 2023-03-20 11:44:01
原創
1893 人瀏覽過

最近在做後台管理的項目,後台通常有資料匯出到 excel 的需要,經過之前搜尋通常建議使用的是 php excel ,我常使用的是 laravel ,對於 php excel 也有很好用的對應 package。
 開始使用是非常好用的,但是當需要匯出的資料達到上萬條時就直接帶來記憶體不足的問題。

這個方案好處的不需要額外的接口,但是要依賴前端開發者。

  • 匯出成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資料匯出與WEB service的問題

PHP資料匯出與WEB service的問題

######PHP資料匯出和WEB service的有關問題################

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板