来源:http://www.jb51.net/article/49313.htm

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

  1. /**
  2. * 导出数据到CSV文件
  3. * @param array $data 数据
  4. * @param array $title_arr 标题
  5. * @param string $file_name CSV文件名
  6. */
  7. function export_csv(&$data, $title_arr, $file_name = '') {
  8. ini_set("max_execution_time", "3600");
  9. $csv_data = '';
  10. /** 标题 */
  11. $nums = count($title_arr);
  12. for ($i = 0; $i < $nums - 1; ++$i) {
  13. $csv_data .= '"' . $title_arr[$i] . '",';
  14. }
  15. if ($nums > 0) {
  16. $csv_data .= '"' . $title_arr[$nums - 1] . "\"\r\n";
  17. }
  18. foreach ($data as $k => $row) {
  19. for ($i = 0; $i < $nums - 1; ++$i) {
  20. $row[$i] = str_replace("\"", "\"\"", $row[$i]);
  21. $csv_data .= '"' . $row[$i] . '",';
  22. }
  23. $csv_data .= '"' . $row[$nums - 1] . "\"\r\n";
  24. unset($data[$k]);
  25. }
  26. $csv_data = mb_convert_encoding($csv_data, "cp936", "UTF-8");
  27. $file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
  28. if (strpos($_SERVER['HTTP_USER_AGENT'], "MSIE")) { // 解决IE浏览器输出中文名乱码的bug
  29. $file_name = urlencode($file_name);
  30. $file_name = str_replace('+', '%20', $file_name);
  31. }
  32. $file_name = $file_name . '.csv';
  33. header("Content-type:text/csv;");
  34. header("Content-Disposition:attachment;filename=" . $file_name);
  35. header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
  36. header('Expires:0');
  37. header('Pragma:public');
  38. echo $csv_data;
  39. }

  

2.保存到文件

  1. function export_csv($data, $title_arr, $file_name = '') {
  2.  
  3. $csv_data = '';
  4.  
  5. /** 标题 */
  6. $nums = count($title_arr);
  7. for ($i = 0; $i < $nums - 1; ++$i) {
  8. $csv_data .= '"' . $title_arr[$i] . '",';
  9. }
  10.  
  11. if ($nums > 0) {
  12. $csv_data .= '"' . $title_arr[$nums - 1] . "\"\r\n";
  13. }
  14.  
  15. foreach ($data as $k => $row) {
  16. for ($i = 0; $i < $nums - 1; ++$i) {
  17. $row[$i] = str_replace("\"", "\"\"", $row[$i]);
  18. $csv_data .= '"' . $row[$i] . '",';
  19. }
  20. $csv_data .= '"' . $row[$nums - 1] . "\"\r\n";
  21. unset($data[$k]);
  22. }
  23.  
  24. $file_name = empty($file_name) ? date('Y-m-d-H-i-s', time()) : $file_name;
  25. file_put_contents($file_name, $csv_data) ;
  26. }

  

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

  1. $file_name="/var/www/tmp/test.csv" ;
  2. $header = array(
  3. '0' => '参数ID',
  4. '1' => '参数名称',
  5. '2' => '统计次数',
  6. '3' => '统计次数百分比',
  7. '4' => '唯一用户数',
  8. '5' => '唯一用户数百分比',
  9. '6' => '人均次数'
  10. );
  11. $csvList = array(array("111", "title", "12", "100%", "23", "50%", "4")) ;
  12. export_csv($csvList, $header, $file_name) ;

  

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

  1. thinkphp导出csv文件,用表格输出excel

    1.thinkphp导出csv文件 导出csv文件可能就那几行代码,今天有个问题困扰我好久,就是导出之后出现一些html代码,这个不应该,view里面是空的,controller中最后也没有$this ...

  2. Scrapy基础(十二)————异步导出Item数据到Mysql中

    异步导出数据到Mysql中 上次说过从Item中同步写入数据库,因为网络的下载速度和数据库的I/O速度是不一样的所以有可能会发生下载快,但是写入数据库速度慢,造成线程的堵塞:关于堵塞和非堵塞,同步和异 ...

  3. 手写网站服务器~用Python手动实现一个简单的服务器,不借助任何框架在浏览器中输出任意内容

    写在前面的一些P话: 在公司网站开发中,我们往往借助于Flask.Django等网站开发框架去提高网站开发效率.那么在面试后端开发工程师的时候,面试官可能就会问到网站开发的底层原理是什么? 我们不止仅 ...

  4. 数据库数据导出CSV文件,浏览器下载

    直接上代码: def download(request): # 从数据库查询数据 data_list = Info.objects.all() # 定义返回对象 response = HttpResp ...

  5. node.js 浏览器中输出 “hello world”

    前段时间花了几个小时,在command面板输出了“hello world”,今天就来说说怎么在浏览器上输入一个地址,然后页面输出“hello world”. 首先要搭建一个基础的 HTTP 服务器 一 ...

  6. mac中导出CSV格式在excel中乱码

    1 - 首先需要查看文档的编码格式: 安装enca:  brew install enca 使用命令 enca  file路径即可查到文件的编码格式 Universal transformation ...

  7. JS在浏览器中输出各种三角形

    直角三角形 <script type="text/javascript"> for(var i=1;i<=8;i++){ for(var j=1;j<=i; ...

  8. 使用Python中的log模块将loss输出到终端与保存到文件

    记得之前对深度学习中得loss输出,经常自己会将输出流重新定向到一个文件中, 比如 python main.py > & | tee log.txt 对于caffe这种c++框架而言,用 ...

  9. 在浏览器中从FTP下载文件

    public static class FTPHelper { /// <summary> /// 得到特定FTP目录的文件列表 /// </summary> /// < ...

随机推荐

  1. POJ 2752Seek the Name, Seek the Fame(next数组妙用 + 既是前缀也是后缀)

    题目链接 题意:求一个字符串中 前缀 和 后缀 相同的长度 分析: 对于一个字符串他自己的长度肯定是可以的.然后如果满足 前缀 和 后缀相等,那个前缀 最后一个字符 一定 和 该字符串最后一个字符相等 ...

  2. Linux Basic --- The First Character in The File Properity

    -rw-r--r-- [d]: content [-]: file [l]: link file [b]: interface device for storage in a device file ...

  3. ES6之模版字符串

    ES6之模版字符串 最近在项目中使用了ES6的模版字符串,在这里加以总结. 1.之前我们也可以使用JavaScript输出模版字符串,通常是下面这样的: $("#result"). ...

  4. 深入理解javascript中执行环境(作用域)与作用域链

    深入理解javascript中执行环境(作用域)与作用域链 相信很多初学者对与javascript中的执行环境与作用域链不能很好的理解,这里,我会按照自己的理解同大家一起分享. 一般情况下,我们把执行 ...

  5. 泛在传感器网络(Ubiquitous Sensor Network; USN)

    http://wiki.mbalib.com/wiki/%E6%B3%9B%E5%9C%A8%E4%BC%A0%E6%84%9F%E5%99%A8%E7%BD%91%E7%BB%9C 什么是泛在传感器 ...

  6. Bootstrap基本类和组件学习二

    一.联系方式:(自带鼠标的移动动画) 1.头文件CSS <link rel="shortcut icon" href="favicon.ico"> ...

  7. Wget命令下载、备份博客

    -np http://www.cnblogs.com/memory4young/p/ 参考资料: http://www.cnblogs.com/memory4young/p/wget-backup-b ...

  8. asp+mysql__不同类型用户登录

    未防注入//0.0 /***这里代码应用场景为多类用户登录,根据用户选择不同的单选按钮判断用户登录的类型,*从而进行不同的数据表进行判断,用户的用户名和密码是否正确.*/ public partial ...

  9. zepto.js之ajax剖析

    1.ajax的baseHeaders ajax插件中的baseHeaders对象的是http请求头部的信息 var mime = settings.accepts[dataType], baseHea ...

  10. 缓存 HttpContext.Current.Cache和HttpRuntime.Cache的区别

    先看MSDN上的解释: HttpContext.Current.Cache:为当前 HTTP 请求获取Cache对象. HttpRuntime.Cache:获取当前应用程序的Cache.  我们再用. ...