首页 php教程 php手册 导出业务数据为表格(csv)文件的一个简单通用的方法

导出业务数据为表格(csv)文件的一个简单通用的方法

Jun 07, 2016 am 11:41 AM

一个通用的下载导出方法
/*<br> * 通用方法<br> * 导出大数据为CSV <br> * 参数依次传入 查询对象,CSV文件列头(键是数据表中的列名,值是csv的列名),文件名.对数据二次处理的函数;<br> */<br> private function DownloadCSV( $selectObject, $head, $fileName = time(), $callBack = '' ){<br>     <br>  if ( !is_object( $selectObject ) || !is_array( $head ) ) {<br>     exit('参数错误!');<br>  }<br> <br>  set_time_limit(0);<br>  //下载头.<br>  header ('Content-Type: application/vnd.ms-excel;charset=gbk');<br>  header ('Content-Disposition: attachment;filename="'.$fileName.'.csv"');<br>  header ('Cache-Control: max-age=0');<br>     <br>  //输出流;<br>  $file = 'php://output';<br>  $fp = fopen ( $file, 'a' );<br> <br>  $changCode = function( $changArr ) {<br>      // 破Excel2003中文只支持GBK编码;<br>      foreach ( $changArr as $k =&gt; $v ) {<br>          $changArr [$k] = iconv ( 'utf-8', 'gbk', $v );<br>      }<br>      //返回一个 索引数组;<br>      return array_values( $changArr );<br>  };<br> <br>  //写入头部;<br>  fputcsv ( $fp, $changCode( $head ) );<br>     <br>  //写入数据;<br>  $pageSize = 100//每次查询一百条;<br>  $page  = 1;//起始页码;<br>  $list = array();<br> <br>  //查库;<br>  $cloneObj = clone $selectObject;//因为thinkphp内部执行完select方法后会清空对象属性,所以clone;<br>     <br>  while ( $list = $cloneObj -&gt;limit( $pageSize*( ($page++)-1 ), $pageSize )-&gt;select()  ) {<br> <br>     $cloneObj = clone $selectObject;<br>             <br>     //对查询结果二次处理<br>     is_callable( $callBack ) &amp;&amp; $list = call_user_func( $callBack, $list );<br> <br>     foreach ( $list as $key =&gt; $value ) {<br>             <br>          $value = array_intersect_key( $value, $head );//返回需要写入CSV的数据;<br>          $value = array_merge( $head, $value );//利用此函数返回需要的顺序;<br>          $value = $changCode( $value );<br>          fputcsv ( $fp, $value );//写入数据;<br>          flush();<br>             <br>     }<br> <br>     ob_flush();<br>                 <br>  }<br> <br>  exit();<br> }//比如有一个方法 demo 在展示数据表时 还要有导出功能.<br> <br> public function demo(){<br> <br> /*<br> <br> 一堆判断搜索,之类的代码.<br> <br> */<br> <br> $list = $table-&gt;field($x)-&gt;join($l)-&gt;where($m);<br> <br> //比如$var是表单发送过来的 开启导出的"开关" <br> if ( $var == 1 )<br> <br>     $headerArr = array('数据表字段'=&gt;'导出时CSV的列名');<br> <br>     $callBack = function( $list ) {<br>         //对数据的二次处理;<br>         return $list;<br>     };<br> <br>     $this-&gt;DownloadCSV( $list, $headerArr, 'XXX'.date('YmdHi',time()), $callBack );<br> <br> }<br> <br> $list = $list-&gt;select();<br> <br> /* 分配到模板等等 */利用thinkphp的model做的通用下载,可以节约很多做下载导出数据功能时也要写一堆 where 搜索判断的问题.

AD:真正免费,域名+虚机+企业邮箱=0元

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

了解Python编程的入门级代码示例 了解Python编程的入门级代码示例 Jan 04, 2024 am 10:50 AM

了解Python编程的入门级代码示例

如何使用PHP编写库存管理系统中的库存分仓管理功能代码 如何使用PHP编写库存管理系统中的库存分仓管理功能代码 Aug 06, 2023 pm 04:49 PM

如何使用PHP编写库存管理系统中的库存分仓管理功能代码

PHP 变量的实际应用:10 个实际使用示例 PHP 变量的实际应用:10 个实际使用示例 Feb 19, 2024 pm 03:00 PM

PHP 变量的实际应用:10 个实际使用示例

Java实现简单的冒泡排序代码 Java实现简单的冒泡排序代码 Jan 30, 2024 am 09:34 AM

Java实现简单的冒泡排序代码

Go语言编程实例:Web开发中的代码示例 Go语言编程实例:Web开发中的代码示例 Mar 04, 2024 pm 04:54 PM

Go语言编程实例:Web开发中的代码示例

华为云边缘计算对接指南:Java代码示例快速实现接口 华为云边缘计算对接指南:Java代码示例快速实现接口 Jul 05, 2023 pm 09:57 PM

华为云边缘计算对接指南:Java代码示例快速实现接口

从入门到精通:Go语言中常用数据结构的代码实现 从入门到精通:Go语言中常用数据结构的代码实现 Mar 04, 2024 pm 03:09 PM

从入门到精通:Go语言中常用数据结构的代码实现

指导与示例:学习Java选择排序算法的实现 指导与示例:学习Java选择排序算法的实现 Feb 18, 2024 am 10:52 AM

指导与示例:学习Java选择排序算法的实现

See all articles