Codeigniter+PHPExcel实现导出数据到Excel文件


Posted in PHP onJune 12, 2014

PHPExcel是用来操作OfficeExcel文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格。而Codeigniter是一个功能强大的PHP框架。二者结合就能起到非常棒的效果啦!

1.准备工作

下载PHPExcel:http://phpexcel.codeplex.com
这是个强大的Excel库,这里只演示导出Excel文件的功能,其中的大部分功能可能都用不着。

2.安装PHPExcel到Codeigniter

1)解压压缩包里的Classes文件夹中的内容到application\libraries\目录下,目录结构如下:
--application\libraries\PHPExcel.php
--application\libraries\PHPExcel(文件夹)
2)修改application\libraries\PHPExcel\IOFactory.php文件
--将其类名从PHPExcel_IOFactory改为IOFactory,遵从CI类命名规则。
--将其构造函数改为public

3.安装完毕,写一个导出excel的控制器(Controller)

代码如下:

<?php
classTable_exportextendsCI_Controller{
    function__construct()
    {
        parent :: __construct();
        // Hereyoushouldaddsomesortofuservalidation
        // topreventstrangersfrompullingyourtabledata
    }
    functionindex($table_name)
    {
        $query = $this -> db -> get($table_name);
        if(!$query)
            returnfalse;
        // StartingthePHPExcellibrary
        $this -> load -> library('PHPExcel');
        $this -> load -> library('PHPExcel/IOFactory');
        $objPHPExcel = newPHPExcel();
        $objPHPExcel -> getProperties() -> setTitle("export") -> setDescription("none");
        $objPHPExcel -> setActiveSheetIndex(0);
        // Fieldnamesinthefirstrow
        $fields = $query -> list_fields();
        $col = 0;
        foreach($fieldsas$field)
        {
            $objPHPExcel -> getActiveSheet() -> setCellValueByColumnAndRow($col, 1, $field);
            $col++;
            }
        // Fetchingthetabledata
        $row = 2;
        foreach($query -> result()as$data)
        {
            $col = 0;
            foreach($fieldsas$field)
            {
                $objPHPExcel -> getActiveSheet() -> setCellValueByColumnAndRow($col, $row, $data -> $field);
                $col++;
                }
            $row++;
            }
        $objPHPExcel -> setActiveSheetIndex(0);
        $objWriter = IOFactory :: createWriter($objPHPExcel, 'Excel5');
        // Sendingheaderstoforcetheusertodownloadthefile
        header('Content-Type:application/vnd.ms-excel');
        header('Content-Disposition:attachment;filename="Products_' . date('dMy') . '.xls"');
        header('Cache-Control:max-age=0');
        $objWriter -> save('php://output');
        }
    }


4.测试

加入数据库有表名为products,此时可以访问http://www.yoursite.com/table_export/index/products导出Excel文件了。
PHP 相关文章推荐
也谈截取首页新闻 - 范例
Oct 09 PHP
php学习笔记 类的声明与对象实例化
Jun 13 PHP
PHP_NETWORK_GETADDRESSES: GETADDRINFO FAILED问题解决办法
May 04 PHP
ThinkPHP中U方法的使用浅析
Jun 13 PHP
VPS中使用LNMP安装WordPress教程
Dec 28 PHP
php实现对象克隆的方法
Jun 20 PHP
在Thinkphp中使用ajax实现无刷新分页的方法
Oct 25 PHP
thinkPHP框架对接支付宝即时到账接口回调操作示例
Nov 14 PHP
PHP多进程之pcntl_fork的实例详解
Oct 15 PHP
PHP微信H5支付开发实例
Jul 25 PHP
PHP进阶学习之类的自动加载机制原理分析
Jun 18 PHP
PHP vsprintf()函数格式化字符串操作原理解析
Jul 14 PHP
Codeigniter生成Excel文档的简单方法
Jun 12 #PHP
PHP 面向对象程序设计(oop)学习笔记 (四) - 异常处理类Exception
Jun 12 #PHP
让CodeIgniter数据库缓存自动过期的处理的方法
Jun 12 #PHP
PHP 面向对象程序设计(oop)学习笔记(三) - 单例模式和工厂模式
Jun 12 #PHP
CodeIgniter启用缓存和清除缓存的方法
Jun 12 #PHP
PHP 面向对象程序设计(oop)学习笔记 (二) - 静态变量的属性和方法及延迟绑定
Jun 12 #PHP
PHP 面向对象程序设计(oop)学习笔记(一) - 抽象类、对象接口、instanceof 和契约式编程
Jun 12 #PHP
You might like
php 获取远程网页内容的函数
2009/09/08 PHP
php语言流程控制中的主动与被动
2012/11/05 PHP
php实现保存submit内容之后禁止刷新
2014/03/19 PHP
PHP 数组黑名单/白名单实例代码详解
2019/06/04 PHP
suggestion开发小结以及对键盘事件的总结(针对中文输入法状态)
2011/12/20 Javascript
仿微博字符限制效果实现代码
2012/04/20 Javascript
js类型转换与引用类型详解(Boolean_Number_String)
2014/03/07 Javascript
javascript几个易错点记录
2014/11/26 Javascript
JavaScript时间转换处理函数
2015/04/14 Javascript
JS禁用页面上所有控件的实现方法(附demo源码下载)
2015/12/17 Javascript
jQuery实现立体式数字动态增加(animate方法)
2016/12/21 Javascript
Node.js中.pfx后缀文件的处理方法
2017/03/10 Javascript
jQuery实现百度登录框的动态切换效果
2017/04/21 jQuery
jQuery实现的简单图片轮播效果完整示例
2018/02/08 jQuery
vue判断input输入内容全是空格的方法
2018/03/02 Javascript
详解angular脏检查原理及伪代码实现
2018/06/08 Javascript
vue+mousemove实现鼠标拖动功能(拖动过快失效问题解决方法)
2018/08/24 Javascript
[33:42]LGD vs OG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
[53:10]完美世界DOTA2联赛决赛日 FTD vs GXR 第二场 11.08
2020/11/11 DOTA
[53:13]DOTA2-DPC中国联赛 正赛 DLG vs PHOENIX BO3 第三场 1月18日
2021/03/11 DOTA
matplotlib中legend位置调整解析
2017/12/19 Python
VSCode下好用的Python插件及配置
2018/04/06 Python
Python键盘输入转换为列表的实例
2018/06/23 Python
如何使用python写截屏小工具
2020/09/29 Python
python关于倒排列的知识点总结
2020/10/13 Python
Pycharm 解决自动格式化冲突的设置操作
2021/01/15 Python
澳大利亚领先的武术用品和健身器材供应商:SMAI
2019/03/24 全球购物
快餐店的创业计划书范文
2014/01/29 职场文书
GMP办公室主任岗位职责
2014/03/14 职场文书
人力资源管理毕业求职信
2014/08/05 职场文书
化工见习报告范文
2014/10/31 职场文书
2016年公务员六五普法心得体会
2016/01/21 职场文书
Python中常见的反爬机制及其破解方法总结
2021/06/10 Python
移除Selenium中window.navigator.webdriver值
2022/06/10 Python
Win2008系统搭建DHCP服务器
2022/06/25 Servers
css中:last-child不生效的解决方法
2022/08/05 HTML / CSS