php 数组导出csv_php导出csv数据(浏览器中输出提供下载或保存到文件)

本节内容:

php导出csv文件的方法,在浏览器中输出下载或保存到文件。

1,在浏览器输出提供下载

复制代码 代码示例:

/**

* 导出数据到CSV文件

* @param array $data  数据

* @param array $title_arr 标题

* @param string $file_name CSV文件名

*/

function export_csv(&$data, $title_arr, $file_name = '') {

ini_set("max_execution_time", "3600");

$csv_data = '';

/** 标题 */

$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,php导出csv数据,并保存到文件

复制代码 代码示例:

function export_csv($data, $title_arr, $file_name = '') {

$csv_data = '';

/** 标题 */

$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) ;

}

附,php导出csv数据的调用示例(保存到文件):

复制代码 代码示例:

$file_name="/var/www/tmp/test.csv" ;

$header = array(

'0' => '参数ID',

'1' => '参数名称',

'2' => '统计次数',

'3' => '统计次数百分比',

'4' => '唯一用户数',

'5' => '唯一用户数百分比',

'6' => '人均次数'

);

$csvList = array(array("111", "title", "12", "100%", "23", "50%", "4")) ;

export_csv($csvList, $header, $file_name) ;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值