资讯专栏INFORMATION COLUMN

ThinkPHP用PHPExcle导出Excel文件

rollback / 1150人阅读

摘要:本篇文章主要讲述,如何在中使用中导出文件,是博主在实践了好多篇别人的帖子之后,总结归纳出来的文章,亲测可用。我的博客欢迎骚扰原文地址用导出文件。将文件,重命名成。文章结束,欢迎转载。

本篇文章主要讲述,如何在thinkPHP中使用PHPExcel中导出Excel文件,是博主在实践了好多篇别人的帖子之后,总结归纳出来的文章,亲测可用。thinkPHP版本是3.2。

我的博客:Mine-MuYan,欢迎骚扰,原文地址:ThinkPHP用PHPExcle导出Excel文件。

准备工作 下载、配置PHPExcel扩展插件

去PHPExcel的官网或者github去下载最新PHPExcel放到ThinkPHP/Library/Vendor目录下,Vendor目录是放置PHP扩展包的默认文件夹,在Vendor目录下建立PHPExcel文件夹,将下载的文件,解压到此处。

PHPExcel.php文件,重命名成PHPExcel.class.php

至此,插件安装已经做好,目录结构如下图,接下来做功能部分。

创建Excel方法 生成Excel文件方法
/**
     * 数据导出为.xls格式
     * @param string $fileName 导出的文件名
     * @param $expCellName     array -> 数据库字段以及字段的注释
     * @param $expTableData    Model -> 连接的数据库
     */
    public function exportExcel($fileName="table",$expCellName,$expTableData){
        $xlsTitle = iconv("utf-8", "gb2312", $fileName);//文件名称
        $xlsName = $fileName.date("_Y.m.d_H.i.s"); //or $xlsTitle 文件名称可根据自己情况设定
        $cellNum = count($expCellName);
        $dataNum = count($expTableData);

        import("Vendor.PHPExcel.PHPExcel");
        import("Vendor.PHPExcel.Writer.Excel5");
        import("Vendor.PHPExcel.IOFactory.php");

        $objPHPExcel = new PHPExcel();
        $cellName = array("A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","AA","AB","AC","AD","AE","AF","AG","AH","AI","AJ","AK","AL","AM","AN","AO","AP","AQ","AR","AS","AT","AU","AV","AW","AX","AY","AZ");

        $objPHPExcel->getActiveSheet(0)->mergeCells("A1:".$cellName[$cellNum-1]."1");//合并单元格
        $objPHPExcel->setActiveSheetIndex(0)->setCellValue("A1", $fileName."  Export time:".date("Y-m-d H:i:s"));
        for($i=0;$i<$cellNum;$i++){
            $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i]."2", $expCellName[$i][1]);
        }
        // Miscellaneous glyphs, UTF-8
        for($i=0;$i<$dataNum;$i++){
            for($j=0;$j<$cellNum;$j++){
                $objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j].($i+3), $expTableData[$i][$expCellName[$j][0]]);
            }
        }

        header("pragma:public");
        header("Content-type:application/vnd.ms-excel;charset=utf-8;name="".$xlsTitle.".xls"");
        header("Content-Disposition:attachment;filename=$xlsName.xls");//attachment新窗口打印inline本窗口打印
        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, "Excel5");
        $objWriter->save("php://output");
        exit;
    }
方法生成说明 第9行的

$xlsName = $fileName.date("_Y.m.d_H.i.s"); //or $xlsTitle 文件名称可根据自己情况设定

是设置文件名,上面所写是文件名_Y.m.d_H.i.s_Y.m.d_H.i.s即是导出的时间,因为windows下,文件名中不能含有:,所以即便写成_Y.m.d_H:i:s,导出的文件也是_Y.m.d_H.i.s这种样式。

第13行~15行的
import("Vendor.PHPExcel.PHPExcel");
import("Vendor.PHPExcel.Writer.Excel5");
import("Vendor.PHPExcel.IOFactory.php");

这三行即是引入PHPExcel,因为当时的文件目录结构是ThinkPHP/Library/Vendor/PHPExcel,所以import("Vendor.PHPExcel.PHPExcel");,注意目录结构,只要引入的位置和放置PHPExcel的目录相同即可;

第20、21行的
$objPHPExcel->getActiveSheet(0)->mergeCells("A1:".$cellName[$cellNum-1]."1");//合并单元格
$objPHPExcel->setActiveSheetIndex(0)->setCellValue("A1", $fileName."  Export time:".date("Y-m-d H:i:s"));

此作用是,在Excel文件的第一行合并一行单元格,用作表格的标题或简介。如下图所示:

setCellValue("A1", $fileName." Export time:".date("Y-m-d H:i:s"));值可以根据自己需求修改;

第34行的

header("Content-Disposition:attachment;filename=$xlsName.xls");//attachment新窗口打印inline本窗口打印

可以设置输出的文件格式,此处写的是.xls,可修改成.xlsx

三个参数

此方法调用时需要传入三个参数(在方法开头的注释中已经说了),这里再具体说明一下:

    $fileName     导出的文件的文件名
    $expCellName  数据库字段以及字段的注释(数组) 
    $expTableData 连接的数据库
方法调用 调用方法
 /**导出**/
    public function msgOut(){
        $excel = A("Excel");
        $xlsCell = array(
            array("id", "ID"),
            array("staff_name", "昵称"),
            array("staff_real", "真实姓名"),
            array("mobile", "手机号"),
            array("card_id", "身份证号"),
            array("referee", "推荐人"),
            array("game_id", "游戏ID"),
            array("money", "余额"),
            array("consume_coin", "消费币"),
            array("create_time", "注册时间"),
            array("status", "状态"),
        );
        $xlsName = "Staff表搜索结果导出";
        $field = null;
        foreach ($xlsCell as $key => $value) {
            if($key == 0){
                $field = $value[0];
            }else{
                $field .= "," . $value[0];
            }
        }
        $xlsModel = M("Staff");
        if (IS_POST) {
            $map = $this -> _queryTime();
            $staff_name = I("staff_name");
            if($staff_name) {
                if (is_numeric($staff_name)) {
                    $map["id|staff_name"] = array(intval($staff_name), array("like", "%" . $staff_name . "%"), "_multi" => true);
                } else {
                    $map["staff_name"] = array("like", "%" . (string)$staff_name . "%");
                }
            }
            $xlsData = $xlsModel->Field($field)->where($map)->order("id DESC")->select();
        }
        foreach ($xlsData as $k => $v) {
            $xlsData[$k]["create_time"] = $v["create_time"] == null ? "-" : date("Y-m-d H:i",$v["create_time"]);
            $xlsData[$k]["status"] = $v["status"] == 1 ? "正常" : "禁用";
        }
        $excel->exportExcel($xlsName,$xlsCell,$xlsData);
    }
调用说明 第3行

$excel = A("Excel");
这个方法我写在了Application/Admin/Controller/ExcelController.class.php中,当前用的控制器是MainController.class.php,调用其他控制器中的方法,用TP中自带的A(),所以第51行,用的是$excel->exportExcel($xlsName,$xlsCell,$xlsData);,如果你的exportExcel()方法和当前调用的方法在同一个控制器内,那么第三行可以不写,第51行改成$this->exportExcel($xlsName,$xlsCell,$xlsData);

第4行

$xlsCell是导出这张表中所有的字段,以及字段的注释,导出后,不能把字段作为表格的列名,不知道数据库字段是什么意思的用户,看了这张表也不知所以然。

第17~24行

是根据$xlsCell数组中,提取出来字段名,作为一个字符串,在查询时使用。当然也可以把这个字段名的字符串手写出来,我这里用的是foreach处理。

第27~38行

是查询条件和查询结果,如果没有查询条件,想把整张表导出的话,直接用 $xlsData = $xlsModel->Field($field)->order("id DESC")->select();即可。

第47~50行

是对$xlsData结果进行处理,我写的两个意思是:

  1.当`create_time`字段为空的时候,值为 `-` ,有值的时候,就用`date()`函数把时间戳处理成日期;
  2.当`status`字段的值为1的时候,显示为`正常`,当值为0的时候`禁用`。

有点罗嗦了,见谅。

模板文件

模板文件很简单,就一个提交。

form表单中三个input,是搜索条件,如果没有的话,直接写button即可。

文章结束,欢迎转载。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/30592.html

相关文章

  • 前端实现Excel导入和导出功能

    摘要:介绍最近项目中让实现一个导入导出的功能,查找了一些插件后发现这个插件,所以就尝试使用了一下,这里将使用方法和遇到的问题简单记录一下。 介绍 最近项目中让实现一个导入导出Excel的功能,查找了一些插件后发现js-xlsx这个插件,所以就尝试使用了一下,这里将使用方法和遇到的问题简单记录一下。 SheetJS js-xlsx 是一款能够读写多种格式表格的插件,浏览器支持良好,并且能在多个...

    Amio 评论0 收藏0
  • phpExcel实现Excel数据的导入导出(全步骤详细解析)

    摘要:上传添加需下载类文件,引入到项目类库里接收前台文件,接收前台文件重设置文件名设置移动路径表用函数方法返回数组创建一个读取数据,可用于入库引用类静态类设置为代表支持或以下版本,代表版开始读取上传到服务器中的文件,返回一个二维数组 1.上传添加excel (需下载PHPExcel类文件,引入到项目类库里) //接收前台文件, public function addExcel() ...

    zengdongbao 评论0 收藏0
  • 导出CSV文件格式错误的小结

    摘要:目前导出方式占用内存较大。比如有些状态字段,数据库存的就是数字或只占一个字节,完全换成中文状态的话,可能达个字节甚至更多。若是必须要用中文形式。中文乱码解决的话,其实也很简单,函数,将转为编码,在中打开就不会错了 问题描述:目前、一般情况下,在web开发过程中,使用导入导出报表的情形很多。我们先说导出。项目数据量多导出行数较多,50万行左右,选择的是csv方式导出。针对以下应用场景,导...

    Taonce 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<