php生成csv文件,下载或者保存到本地。
csv文件的本质就是以换行符和","来作区分的文件。
下载csv函数
<?php
/**
*生成csv文件并下载
*
* @param array $data 要生成的数据
* @param array $title_arr 第一行的头信息
* @param string $file_name 保存的文件名
*/
function createCsv($data, $title_arr, $file_name = '') {
ini_set("max_execution_time", "3600");
$csv_data = '';
foreach ($title_arr as $k => $v) {
$csv_data .= '"' . $v . '",';
}
$csv_data .= PHP_EOL;
foreach ($data as $k => $row) {
foreach ($row as $key => $v) {
$v = str_replace("\"", "\"\"", $v);
$csv_data .= '"' . $v . '",';
}
$csv_data .= PHP_EOL;
unset($data[$k]);
}
$csv_data = function_exists('mb_convert_encoding') ? mb_convert_encoding($csv_data, "cp936", "UTF-8") : iconv("utf-8", "cp936//IGNORE", $csv_data);
/*//TRANSLIT 和 //IGNORE,//TRANSLIT:使用相似字符替换不能转码的字符,//IGNORE:忽视不能转码的字符*/
$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;
}
保存csv到本地
<?php
/**
*生成csv文件并保存到本地
*
* @param array $data 要生成的数据
* @param array $title_arr 第一行的头信息
* @param string $file_name 保存的文件名
*/
function createCsv($data, $title_arr, $file_name = '') {
ini_set("max_execution_time", "3600");
$csv_data = '';
foreach ($title_arr as $k => $v) {
$csv_data .= '"' . $v . '",';
}
$csv_data .= PHP_EOL;
foreach ($data as $k => $row) {
foreach ($row as $key => $v) {
$v = str_replace("\"", "\"\"", $v);
$csv_data .= '"' . $v . '",';
}
$csv_data .= PHP_EOL;
unset($data[$k]);
}
$csv_data = function_exists('mb_convert_encoding') ? mb_convert_encoding($csv_data, "cp936", "UTF-8") : iconv("utf-8", "cp936//IGNORE", $csv_data);
/*//TRANSLIT 和 //IGNORE,//TRANSLIT:使用相似字符替换不能转码的字符,//IGNORE:忽视不能转码的字符*/
$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 = dirname($file_name) . '/' . basename($file_name, '.csv') . '.csv';
file_put_contents($file_name, $csv_data);
}