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