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的更多相关文章

  1. thinkPHP中phpexcel的导出功能

    public function wExcel() { vendor("PHPExcel.PHPExcel"); // Create new PHPExcel object $obj ...

  2. PHPexcel数据导出

    使用PHPexcel数据导出,可以从网上下载phpexcel引入使用,下面是我做的简单的数据导出练习 一.下载phpexcel 二.引发这个导出(我这里是写了一个简单的点击事件) <div id ...

  3. ThinkPHP5使用PHPExcel实现数据导出功能

    1.将PHPExcel类库文件夹放入extend目录下 2.导出功能实现 public function download(){ if(request()->isPost()){ $val = ...

  4. PHPExcel导出数据时字段超过26列出错Invalid cell coordinate [1

    http://blog.csdn.net/dl425134845/article/details/46650961 以下是解决方案函数 /** *   方法名:    getExcel *   作用  ...

  5. jxl写入excel实现数据导出功能

    @RequestMapping(params = "method=export", method = RequestMethod.GET) public void exportCo ...

  6. Excel数据导出功能

    HTML代码: <a id="aExportData" hidden><span>Export</span></a> <div ...

  7. phpexcel: 数据导出

    // 设置列名最多40个 $cols = array( "A", "B", "C", "D", "E" ...

  8. nginx 代理请求导出功能bug解决方法

    问题描述: nginx代理的ip直接访问可以直接下载文件,但是通过nginx访问就报502,nginx错误日志:upstream sent invalid chunked response while ...

  9. 封装Excls数据导出功能 返回一个下载链接地址

    /// <summary> /// 获取本地存储地址 /// </summary> /// <param name="dt"></para ...

随机推荐

  1. hdu2389二分图之Hopcroft Karp算法

    You're giving a party in the garden of your villa by the sea. The party is a huge success, and every ...

  2. 利刃 MVVMLight 8:DispatchHelper在多线程和调度中的使用

    在应用程序中,线程可以被看做是应用程序的一个较小的执行单位.每个应用程序都至少拥有一个线程,我们称为主线程,这是在启动时调用应用程序的主方法时由操作系统分配启动的线程. 当调用和操作主线程的时候,该操 ...

  3. TFS下载文件已损坏问题

    近日在把一个数千人使用的TFS环境进行机房迁移时,从现有的服务器集群中整体迁移到另外一个服务器集群中,经过周密的设计迁移方案,充分验证方案中的各个关键过程,最终在几乎对数千人用户完全透明,没有任何感知 ...

  4. 使用IntelliJ IDEA开发SpringMVC网站(二)开发环境

    访问GitHub下载最新源码:https://github.com/gaussic/SpringMVCDemo 文章已针对IDEA 2016做了一定的更新,部分更新较为重要,请重新阅读文章并下载最新源 ...

  5. sqlmap连接Mysql实现getshell(原创)

    前言 昨天群友发了一知乎的帖子..才发现sqlmap玩了那么久有些玩意我居然没玩过...然后看着群友玩= =今天也想试试. 0x01 首先得知道这个玩意,sqlmap -help,不说大家也懂搜嘎. ...

  6. anjular中Service、Factory、Provider的使用与js中创建对象的总结

    在学习anjular中Service的使用时,发现和js中的创建对象的方式有一定的联系,所以总结了anjular中Service.Factory.Provider的使用方式与js创建对象的方式 一.先 ...

  7. 如何利用动态URL提升SEO及处理业务逻辑

    如果你正在建设一个新网站或者对现有网站重新设计,我们认为应该将网站的 URL 转换为用户友好的 URL,或搜索引擎友好的 URL,这类 URL 也称为语义 URL(Semantic URL).哪些UR ...

  8. 调用Live555接收RTSP直播流,转换为Http Live Streaming(iOS直播)协议

    Live555接收RTSP直播流,转换Http Live Streaming(iOS直播)协议 RTSP协议也是广泛使用的直播/点播流媒体协议,之前实现过一个通过live555接收RTSP协议,然后转 ...

  9. 【WPF MaterialDesign 示例开源项目】 Work Time Manager

    转岗写了将近一年的 PHP 最近因为 工作太多太杂, 在汇报工作的时候经常会忘记自己做了些什么,本来想只是使用excel来记录,但是发现了excel的很多局限性,光是无法共享就郁闷死了,习惯了下班不带 ...

  10. [转]JAVA的动态代理机制及Spring的实现方式

    JAVA 代理实现 代理的实现分动态代理和静态代理,静态代理的实现是对已经生成了的JAVA类进行封装. 动态代理则是在运行时生成了相关代理累,在JAVA中生成动态代理一般有两种方式. JDK自带实现方 ...