本篇文章帶大家介紹PHP如何高效導(dǎo)出Excel(CSV)。有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)大家有所幫助。
PHP高效導(dǎo)出Excel(CSV)
CSV,是Comma Separated Value(逗號(hào)分隔值)的英文縮寫,通常都是純文本文件。
如果你導(dǎo)出的Excel沒(méi)有什么高級(jí)用法的話,只是做導(dǎo)出數(shù)據(jù)用那么建議使用本方法,要比PHPexcel要高效的多。
二十萬(wàn)數(shù)據(jù)導(dǎo)出大概需要2到3秒。
/** * 導(dǎo)出excel(csv) * @data 導(dǎo)出數(shù)據(jù) * @headlist 第一行,列名 * @fileName 輸出Excel文件名 */ function csv_export($data = array(), $headlist = array(), $fileName) { header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="'.$fileName.'.csv"'); header('Cache-Control: max-age=0'); //打開(kāi)PHP文件句柄,php://output 表示直接輸出到瀏覽器 $fp = fopen('php://output', 'a'); //輸出Excel列名信息 foreach ($headlist as $key => $value) { //CSV的Excel支持GBK編碼,一定要轉(zhuǎn)換,否則亂碼 $headlist[$key] = iconv('utf-8', 'gbk', $value); } //將數(shù)據(jù)通過(guò)fputcsv寫到文件句柄 fputcsv($fp, $headlist); //計(jì)數(shù)器 $num = 0; //每隔$limit行,刷新一下輸出buffer,不要太大,也不要太小 $limit = 100000; //逐行取出數(shù)據(jù),不浪費(fèi)內(nèi)存 $count = count($data); for ($i = 0; $i < $count; $i++) { $num++; //刷新一下輸出buffer,防止由于數(shù)據(jù)過(guò)多造成問(wèn)題 if ($limit == $num) { ob_flush(); flush(); $num = 0; } $row = $data[$i]; foreach ($row as $key => $value) { $row[$key] = iconv('utf-8', 'gbk', $value); } fputcsv($fp, $row); } }