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 ...
随机推荐
- 【算法系列学习】[kuangbin带你飞]专题十二 基础DP1 F - Piggy-Bank 【完全背包问题】
https://vjudge.net/contest/68966#problem/F http://blog.csdn.net/libin56842/article/details/9048173 # ...
- 利用GDB进行多线程调试
一.多线程调试 多线程调试重要就是下面几个命令: info thread 查看当前进程的线程. thread <ID> 切换调试的线程为指定ID的线程. break file.c:100 ...
- 全易通人事考勤工资验厂管理系统软件创建连接SQL2000数据库的操作方法和说明
全易通人事考勤工资验厂管理系统软件创建连接SQL2000数据库的操作方法和说明.全易通人事考勤工资验厂管理系统软件,有2种数据库,一个是ACCESS,另一个是SQL.不过由于ACCESS数据库比较小, ...
- 在Android Studio上测试运行,Unity发布成Android包的环境搭建步骤
我用的是unity5.4.3版本,jdk是1.8.0_131版本,Android-SDK是r24.4.1版本,Android-NDK是r13b版本,作者是刚开始写博客,希望对在unity摸索的人有 ...
- 跨域资源共享CORS详解
简介 CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing). 它允许浏览器向跨源服务器,发出XMLHttpRequest请 ...
- iframe框架的应用
同学接私活,我写几个页面. 后台系统,点击侧栏菜单后,右边div的要显示对应的内容.就是说,没选一下左边的菜单,右边的内容都要变化. 这次首先尝试了一下Oldfasional办法--iframe框架. ...
- Ext JS 实现建议词模糊动态搜索功能
代码: new Ext.form.ComboBox({ store: new Ext.data.JsonStore({ idProperty: 'VehicleNo', url: '../ajax/t ...
- DNA比对算法:BWT
DNA比对算法:BWT BWT算法,实质上是前缀树的一种实现.那么什么是前缀树呢? 一.前缀树 对于问题p in S?如果S=rpq,那么p为S前缀rp的一个后缀. 于是,为了判断p in S 是否成 ...
- springcloud(三):服务提供与调用
上一篇文章我们介绍了eureka服务注册中心的搭建,这篇文章介绍一下如何使用eureka服务注册中心,搭建一个简单的服务端注册服务,客户端去调用服务使用的案例. 案例中有三个角色:服务注册中心.服务提 ...
- yaf学习之——生成yaf示例框架
windows 下面的生成yaf示例框架 1,下载 https://github.com/laruence/yaf 2,解压以后得到yaf-master文件夹 3,cmd命令窗口cd到上面解压的文件夹 ...