php導(dǎo)出csv數(shù)據(jù)在瀏覽器中輸出提供下載或保存到文件的示例
1.在瀏覽器輸出提供下載
/**
* 導(dǎo)出數(shù)據(jù)到CSV文件
* @param array $data 數(shù)據(jù)
* @param array $title_arr 標(biāo)題
* @param string $file_name CSV文件名
*/
function export_csv(&$data, $title_arr, $file_name = '') {
ini_set("max_execution_time", "3600");
$csv_data = '';
/** 標(biāo)題 */
$nums = count($title_arr);
for ($i = 0; $i < $nums - 1; ++$i) {
$csv_data .= '"' . $title_arr[$i] . '",';
}
if ($nums > 0) {
$csv_data .= '"' . $title_arr[$nums - 1] . "\"\r\n";
}
foreach ($data as $k => $row) {
for ($i = 0; $i < $nums - 1; ++$i) {
$row[$i] = str_replace("\"", "\"\"", $row[$i]);
$csv_data .= '"' . $row[$i] . '",';
}
$csv_data .= '"' . $row[$nums - 1] . "\"\r\n";
unset($data[$k]);
}
$csv_data = mb_convert_encoding($csv_data, "cp936", "UTF-8");
$file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
if (strpos($_SERVER['HTTP_USER_AGENT'], "MSIE")) { // 解決IE瀏覽器輸出中文名亂碼的bug
$file_name = urlencode($file_name);
$file_name = str_replace('+', '%20', $file_name);
}
$file_name = $file_name . '.csv';
header("Content-type:text/csv;");
header("Content-Disposition:attachment;filename=" . $file_name);
header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
header('Expires:0');
header('Pragma:public');
echo $csv_data;
}
2.保存到文件
function export_csv($data, $title_arr, $file_name = '') {
$csv_data = '';
/** 標(biāo)題 */
$nums = count($title_arr);
for ($i = 0; $i < $nums - 1; ++$i) {
$csv_data .= '"' . $title_arr[$i] . '",';
}
if ($nums > 0) {
$csv_data .= '"' . $title_arr[$nums - 1] . "\"\r\n";
}
foreach ($data as $k => $row) {
for ($i = 0; $i < $nums - 1; ++$i) {
$row[$i] = str_replace("\"", "\"\"", $row[$i]);
$csv_data .= '"' . $row[$i] . '",';
}
$csv_data .= '"' . $row[$nums - 1] . "\"\r\n";
unset($data[$k]);
}
$file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
file_put_contents($file_name, $csv_data) ;
}
調(diào)用示例(保存到文件):
$file_name="/var/www/tmp/test.csv" ;
$header = array(
'0' => '參數(shù)ID',
'1' => '參數(shù)名稱',
'2' => '統(tǒng)計次數(shù)',
'3' => '統(tǒng)計次數(shù)百分比',
'4' => '唯一用戶數(shù)',
'5' => '唯一用戶數(shù)百分比',
'6' => '人均次數(shù)'
);
$csvList = array(array("111", "title", "12", "100%", "23", "50%", "4")) ;
export_csv($csvList, $header, $file_name) ;
- thinkPHP導(dǎo)出csv文件及用表格輸出excel的方法
- 基于php導(dǎo)出到Excel或CSV的詳解(附utf8、gbk 編碼轉(zhuǎn)換)
- PHP導(dǎo)出MySQL數(shù)據(jù)到Excel文件(fputcsv)
- 詳解PHP導(dǎo)入導(dǎo)出CSV文件
- php導(dǎo)出csv格式數(shù)據(jù)并將數(shù)字轉(zhuǎn)換成文本的思路以及代碼分享
- PHP 導(dǎo)出數(shù)據(jù)到淘寶助手CSV的方法分享
- PHP實現(xiàn)CSV文件的導(dǎo)入和導(dǎo)出類
- PHP 實現(xiàn)從數(shù)據(jù)庫導(dǎo)出到.csv文件方法
- php使用指定編碼導(dǎo)出mysql數(shù)據(jù)到csv文件的方法
- php導(dǎo)出CSV抽象類實例
- 原生PHP實現(xiàn)導(dǎo)出csv格式Excel文件的方法示例【附源碼下載】
相關(guān)文章
php實現(xiàn)當(dāng)前頁面點(diǎn)擊下載文件的實例代碼
下面小編就為大家?guī)硪黄猵hp實現(xiàn)當(dāng)前頁面點(diǎn)擊下載文件的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
PHP命令行執(zhí)行整合pathinfo模擬定時任務(wù)實例
下面小編就為大家?guī)硪黄狿HP命令行執(zhí)行整合pathinfo模擬定時任務(wù)實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
yii2 開發(fā)api接口時優(yōu)雅的處理全局異常的方法
這篇文章主要介紹了yii2 開發(fā)api接口時優(yōu)雅的處理全局異常的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
PHP網(wǎng)頁游戲?qū)W習(xí)之Xnova(ogame)源碼解讀(四)
這篇文章主要介紹了PHP網(wǎng)頁游戲Xnova(ogame)源碼解讀的用戶登錄頁面,需要的朋友可以參考下2014-06-06
openai createChatCompletion函數(shù)使用實例
這篇文章主要為大家介紹了openai createChatCompletion函數(shù)使用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
php微信公眾號開發(fā)(3)php實現(xiàn)簡單微信文本通訊
這篇文章主要介紹了php微信公眾號開發(fā)第三課,php實現(xiàn)簡單微信文本通訊,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12
Bo-Blog專用的給Windows服務(wù)器的IIS Rewrite程序
Bo-Blog專用的給Windows服務(wù)器的IIS Rewrite程序...2007-08-08

