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 相关文章推荐
基于PHP CURL用法的深入分析
Jun 09 PHP
PHP字符串的递增和递减示例介绍
Feb 11 PHP
php去掉URL网址中带有PHPSESSID的配置方法
Jul 08 PHP
php实现webservice实例
Nov 06 PHP
php动态生成缩略图并输出显示的方法
Apr 20 PHP
WordPress中&quot;无法将上传的文件移动至&quot;错误的解决方法
Jul 01 PHP
PHP中filter函数校验数据的方法详解
Jul 31 PHP
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程
Dec 21 PHP
PHP实现伪静态方法汇总
Jan 13 PHP
PHP sleep()函数, usleep()函数
Aug 25 PHP
PHP面向对象程序设计OOP继承用法入门示例
Dec 27 PHP
Referer原理与图片防盗链实现方法详解
Jul 03 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基础知识:控制结构
2006/12/13 PHP
php利用header函数实现文件下载时直接提示保存
2009/11/12 PHP
php笔记之:文章中图片处理的使用
2013/04/26 PHP
php实现memcache缓存示例讲解
2013/12/04 PHP
PHP数据库操作之基于Mysqli的数据库操作类库
2014/04/19 PHP
destoon安全设置中需要设置可写权限的目录及文件
2014/06/21 PHP
php时间戳格式化显示友好的时间函数分享
2014/10/21 PHP
php匹配字符中链接地址的方法
2014/12/22 PHP
php启用sphinx全文搜索的实现方法
2014/12/24 PHP
PHP中使用php5-ffmpeg撷取视频图片实例
2015/01/07 PHP
ASP.NET jQuery 实例3 (在TextBox里面阻止复制、剪切和粘贴事件)
2012/01/13 Javascript
编写高性能Javascript代码的N条建议
2015/10/12 Javascript
关于JavaScript中事件绑定的方法总结
2016/10/26 Javascript
关于Node.js中Buffer的一些你可能不知道的用法
2017/03/28 Javascript
Vue学习笔记进阶篇之多元素及多组件过渡
2017/07/19 Javascript
详解Vue路由History mode模式中页面无法渲染的原因及解决
2017/09/28 Javascript
浅谈Angular2 模块懒加载的方法
2017/10/04 Javascript
nginx配置React静态页面的方法教程
2017/11/03 Javascript
javaScript中&quot;==&quot;和&quot;===&quot;的区别详解
2018/03/16 Javascript
vue实现动态显示与隐藏底部导航的方法分析
2019/02/11 Javascript
Nodejs在局域网配置https访问的实现方法
2020/10/17 NodeJs
python和bash统计CPU利用率的方法
2015/07/10 Python
python 环境变量和import模块导入方法(详解)
2017/07/11 Python
python: 自动安装缺失库文件的方法
2018/10/22 Python
Django REST framework 分页的实现代码
2019/06/19 Python
Django中自定义admin Xadmin的实现代码
2019/08/09 Python
免费获得微软MCSD证书赶快行动吧!
2012/11/13 HTML / CSS
意大利团购网站:Groupon意大利
2016/10/11 全球购物
HEMA英国:荷兰原创设计
2018/08/28 全球购物
台湾东南旅游社网站:东南旅游
2019/02/11 全球购物
出国签证在职证明
2014/09/20 职场文书
企业务虚会发言材料
2014/10/20 职场文书
党员志愿者服务倡议书
2015/04/29 职场文书
MySQL 全文索引使用指南
2021/05/25 MySQL
windows安装 redis 6.2.6最新步骤详解
2022/04/26 Redis
MySQL数据库实验实现简单数据库应用系统设计
2022/06/21 MySQL