php导出csv数据在浏览器中输出提供下载或保存到文件的示例


Posted in PHP onApril 24, 2014

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.保存到文件

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

调用示例(保存到文件):

$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) ;
PHP 相关文章推荐
PHP+javascript液晶时钟
Oct 09 PHP
利用static实现表格的颜色隔行显示的代码
Sep 02 PHP
php更新修改excel中的内容实例代码
Feb 26 PHP
PHP将HTML转换成文本的实现代码
Jan 21 PHP
php禁止某ip或ip地址段访问的方法
Feb 25 PHP
typecho插件编写教程(六):调用接口
May 28 PHP
PHP中如何使用session实现保存用户登录信息
Oct 20 PHP
如何批量清理系统临时文件(语言:C#、 C/C++、 php 、python 、java )
Feb 01 PHP
PHP邮件群发机实现代码
Feb 16 PHP
详解PHP中的外观模式facade pattern
Feb 05 PHP
Laravel登录失败次数限制的实现方法
Aug 26 PHP
PHP基本语法
Mar 31 PHP
smarty模板中使用get、post、request、cookies、session变量的方法
Apr 24 #PHP
php冒泡排序、快速排序、快速查找、二维数组去重实例分享
Apr 24 #PHP
php获取中文拼音首字母类和函数分享
Apr 24 #PHP
PHP获取浏览器信息类和客户端地理位置的2个方法
Apr 24 #PHP
php中有关字符串的4个函数substr、strrchr、strstr、ereg介绍和使用例子
Apr 24 #PHP
php计算当前程序执行时间示例
Apr 24 #PHP
php实现的百度搜索某地天气的小偷代码
Apr 23 #PHP
You might like
php中判断数组是一维,二维,还是多维的解决方法
2013/05/04 PHP
php mysql_real_escape_string函数用法与实例教程
2013/09/30 PHP
php利用反射实现插件机制的方法
2015/03/14 PHP
php基于session实现数据库交互的类实例
2015/08/03 PHP
浅谈mysql_query()函数的返回值问题
2016/09/05 PHP
PHP 配置后台登录以及模板引入
2017/01/24 PHP
PHP去除空数组且数组键名重置的讲解
2019/02/28 PHP
Javascript中的window.event.keyCode使用介绍
2011/04/26 Javascript
实现51Map地图接口(示例代码)
2013/11/22 Javascript
使用js判断当前时区TimeZone是否是夏令时
2014/02/23 Javascript
jQuery鼠标事件汇总
2015/08/30 Javascript
基于jQuery实现多层次的手风琴效果附源码
2015/09/21 Javascript
js 定义对象数组(结合)多维数组方法
2016/07/27 Javascript
详解vue项目构建与实战
2017/06/27 Javascript
利用vue + element实现表格分页和前端搜索的方法
2017/12/25 Javascript
Vue父子组建的简单通信之控制开关Switch的实现
2018/06/04 Javascript
小白教程|一小时上手最流行的前端框架vue(推荐)
2019/04/10 Javascript
elementUI table表格动态合并的示例代码
2019/05/15 Javascript
基于mpvue的简单弹窗组件mptoast使用详解
2019/08/02 Javascript
js+springMVC 提交数组数据到后台的实例
2019/09/21 Javascript
Vue-cli打包后部署到子目录下的路径问题说明
2020/09/02 Javascript
python连接mongodb操作数据示例(mongodb数据库配置类)
2013/12/31 Python
在Python中操作文件之read()方法的使用教程
2015/05/24 Python
python中利用xml.dom模块解析xml的方法教程
2017/05/24 Python
python中的itertools的使用详解
2020/01/13 Python
python语言中有算法吗
2020/06/16 Python
德国排名第一的主题公园门票网站:Attraction Tickets Direct
2019/09/09 全球购物
接口中的方法可以是abstract的吗
2015/07/23 面试题
环境科学专业优秀毕业生自荐书
2014/02/03 职场文书
安全生产汇报材料
2014/02/17 职场文书
物业管理专业求职信
2014/06/11 职场文书
幽默自我介绍演讲稿
2014/08/21 职场文书
共青团员自我评价
2015/03/10 职场文书
酒店办公室主任岗位职责
2015/04/01 职场文书
python爬虫--selenium模块
2021/03/31 Python
使用vue判断当前环境是安卓还是IOS
2022/04/12 Vue.js