php导出csv数据在浏览器中输出提供下载或保存到文件的示例
发布:smiling 来源: PHP粉丝网 添加日期:2020-11-20 10:49:30 浏览: 评论:0
这篇文章主要介绍了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 = emptyempty($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 = '';
- /** 标题 */
- $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 = emptyempty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
- file_put_contents($file_name, $csv_data) ;
- }
调用示例(保存到文件):
- $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) ;
Tags: php导出csv
- 上一篇:php url路由入门实例
- 下一篇:php利用curl抓取新浪微博内容示例
相关文章
- ·PHP把导入和导出CSV文件到mysql数据库方法(2014-09-10)
- ·php导出csv格式数据并将数字转换成文本的思路以及代码分享(2021-02-07)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)