php使用ajax导出CSV或者EXCEl(thinkphp)方法
首先我强烈推荐看到这篇文章的你将导出文件设置为csv格式的文件 实际测试导出csv文件的速度是excel文件的10几倍左右
首先我先介绍csv文件的导出的方法:
如果你单纯是在数据导出界面上通过用户点击生成csv或者excel按钮通过服务器往浏览器输出excel或者csv 如果数据量小的化可以使用这样的方法(这种方法无法使用ajax)网上百度一下一堆介绍
这里有较为详细的方法介绍 和源码
我这里介绍的是 当数据量比较大时比如生成excel或者csv文件可能需要 几分钟这时候我们需要在用户点击生成按钮后先生成一个loading框阻止用户随意乱点 将excel或者 csv文件先导出到
服务器端后然后通过ajax方法返回给浏览器一个下载地址用户点击下载地址后下载文件
1.导出csv的话非常简单
核心生成代码:
//这里传入的$data为二维数组
//即为$data = ( array ,array,array)
function create_csv($data,$filename='simple.xls')
{
ini_set('max_execution_time', '0');
//这里的CSV即你项目的根目录下新建一个CSV文件夹
$path = ('CSV/'.iconv('UTF-8','gb2312',$filename));
$fp = fopen($path, 'w');
foreach( $data as $k => $v)
{
foreach ($v as $key => &$value)
{
//将数据值进行在编码 避免中文乱码问题
$value = iconv('UTF-8','gb2312',$value);
}
fputcsv($fp, $v);
}
fclose($fp);
$result = array(
'status' => 1,
'path' =>'CSV/'.$filename
);
return $result;
exit;
}
后台调用代码:
public function generate()
{
//这里data需要处理为二维数据及最终为 $data = (array,array,array)这样
$data = array();
$excel_title =array(
"_id" ,
"bo_subject", );
array_push($data,$excel_title);
...处理真实数据并将其push入$data中
$result = create_csv($data,$filename);
$this->ajaxReturn($result);
}
前台通过jquery进行post:建议先去学习一下layer这个弹出层组件特别不错传送门
代码:
<button style=" float: right;" class="btn" id="generate" url="{:U('generate')}">生成</button>
$('#generate').click(function(event)
{
var url = $(this).attr('url');
//loading层
var index = layer.load(1);
function download(content)
{
layer.open({
type: 1,
content: content,
skin: 'layui-layer-demo',
//样式类名
closeBtn: 1,
shift: 0,
area: ['200px', '105px'],
shadeClose: true,
//开启遮罩关闭
content:content
});
}
$.post(url, function(data) {
if (data.status)
{
layer.close(index);
data.path = '__ROOT__' +'/'+(data.path);
var test = '<a class="download" href =' + data.path + ' target="_blank" >点击下载</a>';
download(test);
}
else {
layer.close(index);
layer.alert('出现错误')
}
}, "json");
});
2.导出excel:(导出excel特别慢 适用场景为更复杂的问题比如导出字体的颜色大小排版控制 并且导出图片之类)
首先我们需要引入phpexcel这个插件下载完后去掉没必要的放在 /ThinkPHP/Library/Vendor/PHPExcel
注意目录结构为如图

核心函数为:
function create_xls($data,$filename='simple.xls')
{
ini_set('max_execution_time', '0');
Vendor('PHPExcel.PHPExcel');
$phpexcel = new PHPExcel();
$phpexcel->getProperties()
->setCreator("HYZ")
->setLastModifiedBy("HYZ")
->setTitle("Office 2007 XLSX Test Document")
->setSubject("Office 2007 XLSX Test Document")
->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
->setKeywords("office 2007 openxml php")
->setCategory("Test result file");
$phpexcel->getActiveSheet()->fromArray($data);
$phpexcel->getActiveSheet()->setTitle('Sheet1');
$phpexcel->setActiveSheetIndex(0);
function saveExcelToLocalFile($objWriter,$filename)
{
// make sure you have permission to write to directory
$filePath = 'Excel/'.$filename;
$objWriter->save($filePath);
return $filePath;
}
// 导出到本地语法
$objWriter = new PHPExcel_Writer_Excel5($phpexcel);
// 导出到界面语法
// $objwriter = PHPExcel_IOFactory::createWriter($phpexcel, 'Excel5');
saveExcelToLocalFile($objWriter,iconv('utf-8','gb2312',$filename));
$response = array(
'result' => 1,
'url' =>'Excel/'.$filename
);
return json_encode($response);
exit;
}
其他的部分基本可以参考生成csv的一样
php使用ajax导出CSV或者EXCEl(thinkphp)方法的更多相关文章
- MVC导出数据到EXCEL新方法:将视图或分部视图转换为HTML后再直接返回FileResult
导出EXCEL方法总结 MVC导出数据到EXCEL的方法有很多种,常见的是: 1.采用EXCEL COM组件来动态生成XLS文件并保存到服务器上,然后转到该文件存放路径即可: 优点:可设置丰富的EXC ...
- ThinkPHP导出CSV、Excel
Thinkphp/Library/Think下新文件文件:Csv.class.php <?php namespace Think; class Csv { //导出csv文件 public fu ...
- fputcsv 导出CSV、Excel DownLoad
以前使用excel导出插件导出50000左右的数据就经常遇到内存不足或者超时等现象,现在自己用fputcsv导出CSV比直接导出excel好多了,导出文件可以直接用excel打开.下载后可放在框架目录 ...
- impala 导出CSV 或excel
1.介绍 impala-shell导入导出 参数说明: • -q query (--query=query) 从命令行执行查询,不进入impala-shell • -d default_db (--d ...
- mysql导出csv文件excel打开后数字用科学计数法显示且低位变0的解决方法
Excel显示数字时,如果数字大于12位,它会自动转化为科学计数法:如果数字大于15位,它不仅用于科学技术费表示,还会只保留高15位,其他位都变0. Excel打开csv文件时,只要字段值都是数字,它 ...
- 网页前端导出CSV,Excel格式文件
通过自己实际测试有以下几种方法 方法一通过a标签实现,把要导出的数据用“\n”和“,”拼接成一个字符串,然后把字符串放到href中,这种方法只支持chrome,firefox等非ie浏览器 html页 ...
- pl/sql developer导出数据到excel的方法
http://yedward.net/?id=92 问题说明:使用pl/sql developer导出数据到excel表格中是非常有必要的,一般的可能直接在导出的时候选择csv格式即可,因为该格式可以 ...
- BS导出csv文件的通用方法(.net)
最近把以前项目里用的导出文件的功能提取成了dll,通过读取Attribute来得到要导出的表头(没有支持多语言),使用时只要组织好要导出的数据,调用方法就好了,希望对大家有用. 使用时只需引用下载包里 ...
- 导出csv用excel打开后数字不用科学计数法显示(0123456显示123456)
从这儿抄过来的: http://zhejiangyinghui.iteye.com/blog/1149526 最近写了一个生成csv的程序,生成的csv其中有一列数字长度为13位,csv中查看没有问题 ...
随机推荐
- 自执行函数与setTimeout结合计算
var v1=0,v2=0,v3=0; for(var i=1;i<=3;i++){ var i2=i; (function(){ ...
- nwjs解决页面透明化,启动时显示白屏的问题
这些天在弄nwjs还好能访问外网,可以看到官方的文档,要不然真是欲哭无泪了,找不到相关的文档解决不了问题.主要说说怎么页面透明化的时候,出现白屏一闪问题吧.主要工具: AngularJS+node+n ...
- Hello Docker (Docker 入门分享)
Hello Docker 1 PPT @ http://download.csdn.net/download/liangread/9431056 TBD
- 2016HUAS_ACM暑假集训4K - 基础DP
我不知道怎么用DP,不过DFS挺好用.DFS思路很明显,搜索.记录,如果刚好找到总价值的一半就说明搜索成功. 题目大意:每组6个数,分别表示价值1到6的物品个数.现在问你能不能根据价值均分. Samp ...
- UIScrollView在AutoLayout下的滚动问题
使用Storyboard编写UI,设置支持AutoLayout. 在其中的一个场景上,添加一个UIScrollView,在对应的代码里增加 - (void)viewDidLoad { [super v ...
- [原创]cocos2d-x研习录-第三阶 特性之瓦片地图集
由于一张大的世界地图或背景图片往往可以由屈指可数的几种地形来表示,每种地形对应于一张小的图片,我们称这些小的地形图片为瓦片.把这些瓦片拼接在一起,组合成一个完整的地图,这就是瓦片地图集的基本原理. C ...
- MATLAB 绘图时的相关心得
matlab中如何调整legend的位置? legend('sinx',-1); %----位于图形框外面-----------------------legend('sinx',0);------- ...
- exiv2 如何改变时间戳
有很多c/c++库可以实现jpeg的exif信息的读取,比如libexif或者CxImage等.但如果我们对jpeg进行有关处理后,想在写入文件时保留原有的exif信息(比如拍摄时间等)就有点棘手了. ...
- handshake_failure
在java 1.6版本中,通过HttpsURLConnection请求class 1(多发生于免费ssl证书,比如沃通或者startssl的)的https网络地址时,可能会报握手异常: Caused ...
- js,addEventListener参数传递
解决方法 因为i相对匿名函数是外面的变量,就把循环绑定的时候,将i的值传入到匿名函数内,就可以了.因此需要在匿名函数(事件函数)外包裹一个匿名函数, 并立即执行. var elems = docume ...