yii2 数据导出 excel导出以及导出数据时列超过26列时解决办法

作者:白狼 出处:http://www.manks.top/article/yii2_excel_extension? 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

先概括下我们接下来要说的大致内容:

数据列表页面导出excel数据,

1、可以根据GridView的filter进行搜索数据并导出

2、可以自行扩展数据导出的时间直接导出数据

//先来看controller层,接收GridView参数并做拼接处理

php controller

//传参导出$paramsExcel = ‘‘; //这个参数是控制接收view层GridView::widget filter的参数if ( ($params = Yii::$app->request->queryParams) ){    if ($params && isset($params[‘xxSearch‘]) && $params[‘xxSearch‘])    {        foreach ($params[‘xxSearch‘] as $k => $v)         {            if ($v)            {                $paramsExcel .= $k.‘=‘.$v.‘&‘;            }        }

    }    $paramsExcel = rtrim($paramsExcel, ‘&‘);}

//看view层我们需要做什么

php 输入页面上的html按钮

<div style="margin-bottom: 30px;">        <?= Html::a(‘导出‘, ‘javascript:ed();‘, [‘class‘ => ‘btn btn-success‘]) ?>        开始时间:<input type="text" name="start_time" />        结束时间:<input type="text" name="end_time" /></div>

上面javascript:ed()方法如下,注意这里我们拼接了controller层传递过来的参数,并自行扩展了时间进行搜索数据

//数据导出function ed (){    var paramsExcel = "<?php echo $paramsExcel; //controller传递过来的参数?>",         url = ‘/xx/export-data‘, //此处xx是控制器        startTime = $.trim($(‘input[name=start_time]‘).val()),         endTime = $.trim($(‘input[name=end_time]‘).val()),        temp = ‘‘;        //需要把view层GridView::widget filter的参数与我们自行扩展的参数拼接融合    if (paramsExcel)    {        temp += ‘?‘+paramsExcel;        if (startTime)            temp += ‘&start_time=‘+startTime;                if (endTime)            temp += ‘&end_time=‘+endTime;    }     else if (startTime)    {        temp += ‘?start_time=‘+startTime;        if (endTime)            temp += ‘&end_time=‘+endTime;    }    else if (endTime)    {        temp += ‘?end_time=‘+endTime;    }    url += temp;    window.location.href=url; //url是我们导出数据的地址,上面的处理都只是进行参数的处理}

//下面我们来看下导出数据的action,暂且命名为controller层的 actionExportData,其中CommonFunc是我们引入的全局性质的公共方法

use common\components\CommonFunc;    /**     * @DESC 数据导出     */    public function actionExportData ()    {        $where = ‘1‘;        $temp = ‘‘;        if ($_GET)        {            foreach ($_GET as $k => $v)            {                if ($k == ‘start_time‘)                {                    $t = date(‘Y-m-d‘, strtotime($v)).‘ 00:00:00‘;                    $temp .= ‘create_time >= \‘‘. $t . ‘\‘ AND ‘;                }                elseif ($k == ‘end_time‘)                {                    $t = date(‘Y-m-d‘, strtotime($v)).‘ 23:59:59‘;                    $temp .= ‘create_time <= \‘‘. $t . ‘\‘ AND ‘;                }                else                {                    $temp .= $k . ‘=\‘‘ . $v . ‘\‘ AND ‘;                }            }            $temp = rtrim($temp, ‘ AND‘);        }

        if ($temp) $where .= ‘ AND ‘.$temp;                //查询数据        $data = ......

        if ($data)        {            //数据处理        }                $header = [‘id‘, ‘用户账号‘, ‘创建时间‘]; //导出excel的表头

        CommonFunc::exportData($data, $header, ‘表头‘, ‘文件名称‘);    }

上面CommonFunc::expertData方法是我们底层扩展php-excel类封装的公共方法,这里才是我们要说的关键,关于 PHPExcel类文件大家可自行下载

No1. 我们走了一个小的弯,分享给大家看看

CommonFunc::expertData方法如下:

   /**     *  @DESC 数据导出      *  @notice max column is z OR 26,overiload will be ignored     *  @notice 缺点:导出数据的列数大于26时报错     *  @example      *  $data = [1, ‘小明‘, ‘25‘];     *  $header = [‘id‘, ‘姓名‘, ‘年龄‘];     *  Myhelpers::exportData($data, $header);     *  @return void, Browser direct output     */    public static function exportData ($data, $header, $title = ‘simple‘, $filename = ‘data‘)    {        //require relation class files        require(Yii::getAlias(‘@common‘).‘/components/phpexcel/PHPExcel.php‘);        require(Yii::getAlias(‘@common‘).‘/components/phpexcel/PHPExcel/Writer/Excel2007.php‘);            if (!is_array ($data) || !is_array ($header)) return false;

        //列数        $captions = [‘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‘];

        $objPHPExcel = new \PHPExcel();

        // Set properties        $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");        $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");        $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");        $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");        $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");

        // Add some data        $objPHPExcel->setActiveSheetIndex(0);

        //添加头部        $cheader = count($header);        for ($ci = 1; $ci <= $cheader; $ci++)         {            if ($ci > 25) break;             $objPHPExcel->getActiveSheet()->SetCellValue($captions[$ci-1].‘1‘, $header[$ci-1]);        }

        //添加数据        $i = 2;        $count = count($data);

        foreach ($data as $v)        {            $j = 0;            foreach ($v as $_k => $_v)            {                $objPHPExcel->getActiveSheet()->SetCellValue($captions[$j].$i, $_v);                $j++;            }            if ($i <= $count)            {                $i ++;            }        }

        // Rename sheet        $objPHPExcel->getActiveSheet()->setTitle($title);

        // Save Excel 2007 file        $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);

        header(‘Pragma:public‘);        header("Content-Type:application/x-msexecl;name=\"{$filename}.xls\"");        header("Content-Disposition:inline;filename=\"{$filename}.xls\"");

        $objWriter->save(‘php://output‘);        }

下面是最终的解决方案,也是非常实用的数据导出方案

/**     *  @DESC 数据导     *  @notice 解决了上面导出列数过多的问题     *  @example      *  $data = [1, ‘小明‘, ‘25‘];     *  $header = [‘id‘, ‘姓名‘, ‘年龄‘];     *  Myhelpers::exportData($data, $header);     *  @return void, Browser direct output     */    public static function exportData ($data, $header, $title = ‘simple‘, $filename = ‘data‘)    {        //require relation class files        require(Yii::getAlias(‘@common‘).‘/components/phpexcel/PHPExcel.php‘);        require(Yii::getAlias(‘@common‘).‘/components/phpexcel/PHPExcel/Writer/Excel2007.php‘);            if (!is_array ($data) || !is_array ($header)) return false;

        $objPHPExcel = new \PHPExcel();

        // Set properties        $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");        $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");        $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");        $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");        $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");

        // Add some data        $objPHPExcel->setActiveSheetIndex(0);

        //添加头部        $hk = 0;        foreach ($header as $k => $v)        {            $colum = \PHPExcel_Cell::stringFromColumnIndex($hk);            $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.‘1‘, $v);            $hk += 1;        }

        $column = 2;        $objActSheet = $objPHPExcel->getActiveSheet();        foreach($data as $key => $rows)  //行写入        {            $span = 0;            foreach($rows as $keyName => $value) // 列写入            {                $j = \PHPExcel_Cell::stringFromColumnIndex($span);                $objActSheet->setCellValue($j.$column, $value);                $span++;            }            $column++;        }

        // Rename sheet        $objPHPExcel->getActiveSheet()->setTitle($title);

        // Save Excel 2007 file        $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);

        header(‘Pragma:public‘);        header("Content-Type:application/x-msexecl;name=\"{$filename}.xls\"");        header("Content-Disposition:inline;filename=\"{$filename}.xls\"");

        $objWriter->save(‘php://output‘);        }
时间: 2024-12-23 23:31:46

yii2 数据导出 excel导出以及导出数据时列超过26列时解决办法的相关文章

phpexcel导出excel的数据超过26列怎么办 Invalid cell coordinate [1(THINKPHP3.2中开发遇到的)

最近有个需求,THINKPHP3.2中对数据进行导出,数据一共有43项,导出时候就会抱错 Invalid cell coordinate [1 因为phpexcel 的cell.php里默认就设置了26列,而且判断方法里默认从a-z然后下一个列就是aa1了 ,而实际上在excel里z后面应该是AA,AB,AC,AD,AE,AF这样 所以需要改判断方法,我之前写过一篇excel的导出,只需要吧其中一个方法改动一下,改动的思想就是 当超过26列的时候 下一列命名应该是AA,AB,而不是  aa1,A

C# 使用Epplus导出Excel [2]:导出动态列数据

上一篇导出excel,是导出已知固定列,有时候我们根本就不知道有几列.列名是什么,因此这些动态列,可以用Dictionary<string,string>接收. 1.实体Student上加上一个字段Dictionarys Student.cs public class Student { public String Name { get; set; } public String Code { get; set; } public Dictionary<string, string>

phpexcel导出超过26列解决方案

原文:phpexcel导出超过26列解决方案 将列的数字序号转成字母使用,代码如下:  PHPExcel_Cell::stringFromColumnIndex($i); // 从o,1,2,3,..开始,相应返回返回 A,B,C,...Z,AA,AB,...   将列的字母转成数字序号使用,代码如下:   PHPExcel_Cell::columnIndexFromString('AA'); 使用phpexcel导出excel文件的时候,发现报了一个错误,后来查询问题才发现是列数超过26列的问

使用oledb读写excel出现“操作必须使用一个可更新的查询”的解决办法

使用oledb读写excel出现"操作必须使用一个可更新的查询"的解决办法 转自:http://www.cnblogs.com/Richinger/archive/2008/09/28/1301170.html 前两天使用oledb连接excel的办法为单位某部门从一个excel的多个sheet中作连选抽出需要的数据,程序非常简单,结果很快就出来,原来手工需要很长时间才能选出的结果现在几乎一点击就有了结果.使用人员非常满意,由于是多人使用,开始只是将结果显示在一个页面上.后来他们要求将

java代码导出数据到Excel、js导出数据到Excel(三)

jsp内容忽略,仅写个出发按钮: <button style="width: 100px" onclick="expertExcel()" >JS导出Excel</button>           <button style="width: 100px" onclick="expertWord()" >JS导出Word</button>           <button

js导出excel:前端当前数据的导出

网上找的库文件,同样做了修改.在导出的时候,有时候数据第一列和最后一列可能是复选框和操作按钮,这个是我们不需要的,加了这个的过滤 //table2excel.js /* * jQuery table2excel - v1.1.1 * jQuery plugin to export an .xls file in browser from an HTML table * https://github.com/rainabba/jquery-table2excel * * Made by raina

Element-ui组件库Table表格导出Excel表格--存在重复数据问题

借鉴:https://www.jianshu.com/p/1971fc5b97ca https://blog.csdn.net/qq_40614207/article/details/94003793 贴出代码 // 定义导出Excel表格事件 exportExcel() { // 解决生成重复数据-因为使用l fixed属性 var fix = document.querySelector('.el-table__fixed') var wb // 判断要导出的节点中是否有fixed的表格,如

C# NPOI导出Excel和EPPlus导出Excel比较

系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http://npoi.codeplex.com/ EPPlus官网地址:http://epplus.codeplex.com/ 添加NPOI.EPPlus类库dll使用的是NuGet添加. 在类库References右键Manage NuGet Packages...,之后选择添加对应的dll. 测试结果显

VBS读取txt文档数据查找Excel中单元格数据符合条件的剪切到工作表2中

Dim fso,f,a set oExcel = CreateObject( "Excel.Application" ) oExcel.Visible = false '4) 打开已存在的工作簿: oExcel.WorkBooks.Open( "F:\1.xlsx" ) On Error Resume Next '判断是否存在Sheet2工作表,不存在新建 If oExcel.WorkSheets("Sheet2") Is Nothing The