1. 程式人生 > 實用技巧 >用 PHP 自帶函式 fputcsv 和 fgetcsv 來匯出和匯入csv

用 PHP 自帶函式 fputcsv 和 fgetcsv 來匯出和匯入csv

PHP 自帶函式 fputcsv 可以實現列印報表(Excel)功能。如果你的對報表格式要求不是很高,那麼 fputcsv 是很好的選擇。它執行效率高,不需要第三方庫,用起來很方便。

一、用 fputcsv 匯出報表

<?php

$list = array
(
"George,John,Thomas,USA",
"James,Adrew,Martin,USA",
);

$file = fopen("contacts.csv","w");

foreach ($list as $line){
  fputcsv($file,split(',',$line));
}
fclose($file);
?>

以上程式碼會在本地生成一個 csv 的檔案,能夠用 Excel 開啟,是不是很簡單呢。如果有中文,在 Linux 執行後,下載到本地開啟會亂碼,那麼可以用 iconv 函式進行轉換。

$list = array();
$tmp = "訂單號,訂單支付金額,幸運號碼,使用者名稱,使用者型別,期別,號碼產生時間,開獎時間,獎項標識,獎項,獎金,備註";
$list[] = iconv('UTF-8', 'GB2312//IGNORE',$tmp);   

直接把生成的 CSV 輸出到瀏覽器

header ( 'Content-Disposition: attachment; filename=contacts.csv');//如果檔名是中文的, urlencode 之後在IE不會出現中文亂碼
header ( 'Content-type: application/octet-stream; charset=gbk' );
header ( 'Content-Length: '.filesize ('contacts.csv') );//檔案的大小
readfile ($file_path);
exit ();  

二、用 fgetcsv 匯入報表

用 fgetcsv 匯入報表有一點需要注意的地方。就是必須把 EXCEL 文件轉換成 CSV 格式。注意:不是簡單的改字尾名。

<?php

$file = fopen("contacts.csv","r");
while(! feof($file)){
	print_r(fgetcsv($file));
}
fclose($file);

參考:https://blog.csdn.net/keplerpig/article/details/80736449