首先我强烈推荐看到这篇文章的你将导出文件设置为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)方法的更多相关文章

  1. MVC导出数据到EXCEL新方法:将视图或分部视图转换为HTML后再直接返回FileResult

    导出EXCEL方法总结 MVC导出数据到EXCEL的方法有很多种,常见的是: 1.采用EXCEL COM组件来动态生成XLS文件并保存到服务器上,然后转到该文件存放路径即可: 优点:可设置丰富的EXC ...

  2. ThinkPHP导出CSV、Excel

    Thinkphp/Library/Think下新文件文件:Csv.class.php <?php namespace Think; class Csv { //导出csv文件 public fu ...

  3. fputcsv 导出CSV、Excel DownLoad

    以前使用excel导出插件导出50000左右的数据就经常遇到内存不足或者超时等现象,现在自己用fputcsv导出CSV比直接导出excel好多了,导出文件可以直接用excel打开.下载后可放在框架目录 ...

  4. impala 导出CSV 或excel

    1.介绍 impala-shell导入导出 参数说明: • -q query (--query=query) 从命令行执行查询,不进入impala-shell • -d default_db (--d ...

  5. mysql导出csv文件excel打开后数字用科学计数法显示且低位变0的解决方法

    Excel显示数字时,如果数字大于12位,它会自动转化为科学计数法:如果数字大于15位,它不仅用于科学技术费表示,还会只保留高15位,其他位都变0. Excel打开csv文件时,只要字段值都是数字,它 ...

  6. 网页前端导出CSV,Excel格式文件

    通过自己实际测试有以下几种方法 方法一通过a标签实现,把要导出的数据用“\n”和“,”拼接成一个字符串,然后把字符串放到href中,这种方法只支持chrome,firefox等非ie浏览器 html页 ...

  7. pl/sql developer导出数据到excel的方法

    http://yedward.net/?id=92 问题说明:使用pl/sql developer导出数据到excel表格中是非常有必要的,一般的可能直接在导出的时候选择csv格式即可,因为该格式可以 ...

  8. BS导出csv文件的通用方法(.net)

    最近把以前项目里用的导出文件的功能提取成了dll,通过读取Attribute来得到要导出的表头(没有支持多语言),使用时只要组织好要导出的数据,调用方法就好了,希望对大家有用. 使用时只需引用下载包里 ...

  9. 导出csv用excel打开后数字不用科学计数法显示(0123456显示123456)

    从这儿抄过来的: http://zhejiangyinghui.iteye.com/blog/1149526 最近写了一个生成csv的程序,生成的csv其中有一列数字长度为13位,csv中查看没有问题 ...

随机推荐

  1. 使用 Fluent API 配置/映射属性和类型(摘自微软Data Access and Storage)

    使用 Fluent API 配置/映射属性和类型 使用实体框架 Code First 时,默认行为是使用一组 EF 中内嵌的约定将 POCO 类映射到表.但是,有时您无法或不想遵守这些约定,需要将实体 ...

  2. CentOS7关闭防火墙方法

    在之前的版本中关闭防火墙等服务的命令是 service iptables stop /etc/init.d/iptables stop 在RHEL7中,其实没有这个服务 [root@rhel7 ~]# ...

  3. 闪回恢复区大小不够。报ORA-19809、ORA-19804

    问题: 闪回恢复区大小不够,rman默认备份路径报错.RMAN> backup database;Starting backup at 01-DEC-14using target databas ...

  4. sqlalchemy数据模型

    sqlalchemy在python里作为orm还是比较有名气的,以下是建立的几个简单模型,完全可和flask的数据持久层分离. # coding: utf8 from sqlalchemy impor ...

  5. 转载:python中的StringIO模块

    注意:python3中应使用io.StringIO StringIO经常被用来作为字符串的缓存,应为StringIO有个好处,他的有些接口和文件操作是一致的,也就是说用同样的代码,可以同时当成文件操作 ...

  6. PHP 数组转码

    /** * 数组转码 * @param array $arr 要转码的数组 * @param string $in_charset 输入的字符集 * @param string $out_charse ...

  7. Weblogic是瓦特?和JVM是瓦特关系?

    所谓固定内存60M是瓦特? 以下内容是个瓦特? “总内存大小=堆内存+非堆内存1200m:为堆内存大小,如果不指定后者参数则有最大数限制,网上很多文章认为这就是JVM内存,-Xmx为设置最大堆内存60 ...

  8. UTF-8编码的字符串拆分成单字、获取UTF-8字符串的字符个数的代码及原理

    一.字符编码简介 1. ASCII码 在计算机内部,所有的信息最终都表示为一个二进制的字符串.每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称为一个字节(by ...

  9. ashx文件不能使用DAL和Model的解决办法

    好久没有写web程序了,今天在写web程序时,发现一个问题,在ashx文件中,已经using了DAL和Model命名空间,而且引用中也引用了程序集,可是还报错:未能找到类型或命名空间"Mod ...

  10. MySQL中优化sql语句查询常用的种方法

    1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索 ...