ThinkPHP 整合 PHPExcel ,数据导出功能实现,解决Invalid cell coordinate
PHPExcel想必大家都不陌生,是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格
本次只做数据导出功能的实现,而且我也只做了数据导出(  ̄ー ̄)!
废话少说
1. 导入类库
首先需要下载类库,官方网站:http://phpexcel.codeplex.com/
将下载下来的包解压:PHPExcel_1.8.0_doc.zip\Classes下面的文件就是我们需要的
ThinkPHP第三方类需要放在/ThinkPHP/Library/Vendor下面,新建一个文件夹PHPExcel,将需要的类放进去
2. 工具类
我在Application目录下新建个模块Lib,用于存放公共的工具类
新建文件 ExcelOperation.class.php
代码如下:有需要的可以自己扩展
17.04.22-更新:解决表头超过26列报错:Invalid cell coordinate
这种错误主要是表头AA,AB,AC...,ord()转换问题
<?php /** * PHPExcel * Created by dbn * Date: 2016/12/15 */ namespace Lib; class ExcelOperation { public function __construct() { vendor('PHPExcel.PHPExcel'); vendor('PHPExcel.PHPExcel.IOFactory'); vendor('PHPExcel.PHPExcel.Writer.Excel5'); vendor('PHPExcel.PHPExcel.Writer.Excel2007'); } /** * 数据导出 * @param string $fileName 文件名 * @param array $headArr 表头数据(一维) * @param array $data 列表数据(二维) * @param int $width 列宽 * @return bool */ public function push($fileName="", $headArr=array(), $data=array(), $width=20) { if (empty($headArr) && !is_array($headArr) && empty($data) && !is_array($data)) { return false; } $date = date("YmdHis",time()); $fileName .= "_{$date}.xls"; $objPHPExcel = new \PHPExcel(); //设置表头 $tem_key = "A"; foreach($headArr as $v){ if (strlen($tem_key) > 1) { $arr_key = str_split($tem_key); $colum = ''; foreach ($arr_key as $ke=>$va) { $colum .= chr(ord($va)); } } else { $key = ord($tem_key); $colum = chr($key); } $objPHPExcel->getActiveSheet()->getColumnDimension($colum)->setWidth($width); // 列宽 $objPHPExcel->getActiveSheet()->getStyle($colum)->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER); // 垂直居中 $objPHPExcel->getActiveSheet()->getStyle($colum.'1')->getFont()->setBold(true); // 字体加粗 $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v); $tem_key++; } $objActSheet = $objPHPExcel->getActiveSheet(); $border_end = 'A1'; // 边框结束位置初始化 // 写入内容 $column = 2; foreach($data as $key => $rows){ //获取一行数据 $tem_span = "A"; foreach($rows as $keyName=>$value){// 写入一行数据 if (strlen($tem_span) > 1) { $arr_span = str_split($tem_span); $j = ''; foreach ($arr_span as $ke=>$va) { $j .= chr(ord($va)); } } else { $span = ord($tem_span); $j = chr($span); } $objActSheet->setCellValue($j.$column, $value); $border_end = $j.$column; $tem_span++; } $column++; } $objActSheet->getStyle("A1:".$border_end)->getBorders()->getAllBorders()->setBorderStyle(\PHPExcel_Style_Border::BORDER_THIN); // 设置边框 $fileName = iconv("utf-8", "gb2312", $fileName); //重命名表 //$objPHPExcel->getActiveSheet()->setTitle('test'); //设置活动单指数到第一个表 $objPHPExcel->setActiveSheetIndex(0); ob_end_clean();//清除缓冲区,避免乱码 header('Content-Type: application/vnd.ms-excel'); header("Content-Disposition: attachment;filename=\"$fileName\""); header('Cache-Control: max-age=0'); $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); //文件通过浏览器下载 exit; } }
PHPExcel在绘制样式时会做大量的时间,当数据量过大时,大家要有个取舍!
注:表头和内容顺序一定要对应上
ThinkPHP 整合 PHPExcel ,数据导出功能实现,解决Invalid cell coordinate的更多相关文章
- thinkPHP中phpexcel的导出功能
public function wExcel() { vendor("PHPExcel.PHPExcel"); // Create new PHPExcel object $obj ...
- PHPexcel数据导出
使用PHPexcel数据导出,可以从网上下载phpexcel引入使用,下面是我做的简单的数据导出练习 一.下载phpexcel 二.引发这个导出(我这里是写了一个简单的点击事件) <div id ...
- ThinkPHP5使用PHPExcel实现数据导出功能
1.将PHPExcel类库文件夹放入extend目录下 2.导出功能实现 public function download(){ if(request()->isPost()){ $val = ...
- PHPExcel导出数据时字段超过26列出错Invalid cell coordinate [1
http://blog.csdn.net/dl425134845/article/details/46650961 以下是解决方案函数 /** * 方法名: getExcel * 作用 ...
- jxl写入excel实现数据导出功能
@RequestMapping(params = "method=export", method = RequestMethod.GET) public void exportCo ...
- Excel数据导出功能
HTML代码: <a id="aExportData" hidden><span>Export</span></a> <div ...
- phpexcel: 数据导出
// 设置列名最多40个 $cols = array( "A", "B", "C", "D", "E" ...
- nginx 代理请求导出功能bug解决方法
问题描述: nginx代理的ip直接访问可以直接下载文件,但是通过nginx访问就报502,nginx错误日志:upstream sent invalid chunked response while ...
- 封装Excls数据导出功能 返回一个下载链接地址
/// <summary> /// 获取本地存储地址 /// </summary> /// <param name="dt"></para ...
随机推荐
- 如何高效的进行WebService接口性能测试
版权声明:本文为原创文章,转载请先联系并标明出处 关于接口测试的理解,主要有两类,一类是模块与模块间的调用,此类接口测试应该归属于单元测试的范畴,主要测试模块与模块之间联动调用与返回.此类测试大多关注 ...
- 浅谈OA办公软件市场行情
3.原文:http://www.jiusi.net/detail/472__776__3999__1.html 关键词:oa系统,OA办公软件 浅谈OA办公软件市场行情 中国的OA办公软件市场历经20 ...
- OC继承以及实例变量修饰符
这里基本上跟java一样 所以就简单写几点要注意的: 1)OC与java一样都只支持单继承可以多层继承(java单继承多实现) 2) OC中的实例变量修饰符前要加 @ 例如 @private 例如下面 ...
- Day1 Python 介绍及基础
******************本文目录******************一.Pyhon基本介绍 1.Why Python? 2. Python 是一门什么样的语言? 3.Python的优缺点: ...
- 使用java API操作hdfs--拷贝部分文件到本地
要求:和前一篇的要求正好相反.. 在HDFS中生成一个130KB的文件: 代码如下: import java.io.IOException; import org.apache.hadoop.conf ...
- Java学习笔记——设计模式之五.工厂方法
水边一只青蛙在笑 --石头和水 工厂方法模式(Factory Method),定义了一个用于创建对象的接口,让实现类决定实例化哪一个类.工厂方法使一个类的实例化延迟到其子类. 这里在简单和工厂的基础上 ...
- 微信小程序开发之获取openid及用户信息
1. 获取openid 1.1 获取code 调用接口获取登录凭证(code)进而换取用户登录态信息,包括用户的唯一标识(openid) 及本次登录的会话密钥(session_key).用户数据的加解 ...
- Promise简介
Promise是ES6中的函数,规范了如何处理异步任务的回调函数,功能类似于jQuery的defferred.简单说就是通过promise对象的不同状态调用不同的回调函数.目前IE8及以下不支持,其他 ...
- 【转】jQuery Validate验证框架详解
jQuery校验官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation 一.导入js库 <script type=& ...
- APP为什么需要着陆页
小编APP运营团队一直认为,虽然大多数的用户会在App Store或安卓应用商店中搜寻我们的应用,但也有许多用户会通过传统的PC端搜索来寻找答案.而且在APP营销中,为了更好的将用户转换为下载或购买, ...