yii2 数据导出 excel导出以及导出数据时列超过26列时解决办法,yii226列
yii2 数据导出 excel导出以及导出数据时列超过26列时解决办法,yii226列
作者:白狼 出处:http://www.manks.top/article/yii2_excel_extension 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
先概括下我们接下来要说的大致内容:
数据列表页面导出excel数据,
1、可以根据GridView的filter进行搜索数据并导出
2、可以自行扩展数据导出的时间直接导出数据
//先来看controller层,接收GridView参数并做拼接处理
php controller
//传参导出<br />$paramsExcel = ''; //这个参数是控制接收view层GridView::widget filter的参数<br />if ( ($params = Yii::$app->request->queryParams) )<br />{<br /> if ($params && isset($params['xxSearch']) && $params['xxSearch'])<br /> {<br /> foreach ($params['xxSearch'] as $k => $v) <br /> {<br /> if ($v)<br /> {<br /> $paramsExcel .= $k.'='.$v.'&';<br /> }<br /> }<br /><br /> }<br /> $paramsExcel = rtrim($paramsExcel, '&');<br />}
//看view层我们需要做什么
php 输入页面上的html按钮
<div style="margin-bottom: 30px;"><br /> <?= Html::a('导出', 'javascript:ed();', ['class' => 'btn btn-success']) ?><br /> 开始时间:<input type="text" name="start_time" /><br /> 结束时间:<input type="text" name="end_time" /><br /></div>
上面javascript:ed()方法如下,注意这里我们拼接了controller层传递过来的参数,并自行扩展了时间进行搜索数据
//数据导出<br />function ed ()<br />{<br /> var paramsExcel = "<?php echo $paramsExcel; //controller传递过来的参数?>", <br /> url = '/xx/export-data', //此处xx是控制器<br /> startTime = $.trim($('input[name=start_time]').val()), <br /> endTime = $.trim($('input[name=end_time]').val()),<br /> temp = '';<br /> <br /> //需要把view层GridView::widget filter的参数与我们自行扩展的参数拼接融合<br /> if (paramsExcel)<br /> {<br /> temp += '?'+paramsExcel;<br /> if (startTime)<br /> temp += '&start_time='+startTime;<br /> <br /> if (endTime)<br /> temp += '&end_time='+endTime;<br /> } <br /> else if (startTime)<br /> {<br /> temp += '?start_time='+startTime;<br /> if (endTime)<br /> temp += '&end_time='+endTime;<br /> }<br /> else if (endTime)<br /> {<br /> temp += '?end_time='+endTime;<br /> }<br /> url += temp;<br /> window.location.href=url; //url是我们导出数据的地址,上面的处理都只是进行参数的处理<br />}
//下面我们来看下导出数据的action,暂且命名为controller层的 actionExportData,其中CommonFunc是我们引入的全局性质的公共方法
use common\components\CommonFunc;<br /> /**<br /> * @DESC 数据导出<br /> */<br /> public function actionExportData ()<br /> {<br /> $where = '1';<br /> $temp = '';<br /> if ($_GET)<br /> {<br /> foreach ($_GET as $k => $v)<br /> {<br /> if ($k == 'start_time')<br /> {<br /> $t = date('Y-m-d', strtotime($v)).' 00:00:00';<br /> $temp .= 'create_time >= \''. $t . '\' AND ';<br /> }<br /> elseif ($k == 'end_time')<br /> {<br /> $t = date('Y-m-d', strtotime($v)).' 23:59:59';<br /> $temp .= 'create_time <= \''. $t . '\' AND ';<br /> }<br /> else<br /> {<br /> $temp .= $k . '=\'' . $v . '\' AND ';<br /> }<br /> }<br /> $temp = rtrim($temp, ' AND');<br /> }<br /><br /> if ($temp) $where .= ' AND '.$temp;<br /> <br /> //查询数据<br /> $data = ......<br /><br /> if ($data)<br /> {<br /> //数据处理<br /> }<br /> <br /> $header = ['id', '用户账号', '创建时间']; //导出excel的表头<br /><br /> CommonFunc::exportData($data, $header, '表头', '文件名称');<br /> }
上面CommonFunc::expertData方法是我们底层扩展php-excel类封装的公共方法,这里才是我们要说的关键,关于 PHPExcel类文件大家可自行下载
No1. 我们走了一个小的弯,分享给大家看看
CommonFunc::expertData方法如下:
/**<br /> * @DESC 数据导出 <br /> * @notice max column is z OR 26,overiload will be ignored<br /> * @notice 缺点:导出数据的列数大于26时报错<br /> * @example <br /> * $data = [1, '小明', '25'];<br /> * $header = ['id', '姓名', '年龄'];<br /> * Myhelpers::exportData($data, $header);<br /> * @return void, Browser direct output<br /> */<br /> public static function exportData ($data, $header, $title = 'simple', $filename = 'data')<br /> {<br /> //require relation class files<br /> require(Yii::getAlias('@common').'/components/phpexcel/PHPExcel.php');<br /> require(Yii::getAlias('@common').'/components/phpexcel/PHPExcel/Writer/Excel2007.php');<br /> <br /> if (!is_array ($data) || !is_array ($header)) return false;<br /><br /> //列数<br /> $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'];<br /><br /> $objPHPExcel = new \PHPExcel();<br /><br /> // Set properties<br /> $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");<br /> $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");<br /> $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");<br /> $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");<br /> $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");<br /><br /> // Add some data<br /> $objPHPExcel->setActiveSheetIndex(0);<br /><br /> //添加头部<br /> $cheader = count($header);<br /> for ($ci = 1; $ci <= $cheader; $ci++) <br /> {<br /> if ($ci > 25) break; <br /> $objPHPExcel->getActiveSheet()->SetCellValue($captions[$ci-1].'1', $header[$ci-1]);<br /> }<br /><br /> //添加数据<br /> $i = 2;<br /> $count = count($data);<br /><br /> foreach ($data as $v)<br /> {<br /> $j = 0;<br /> foreach ($v as $_k => $_v)<br /> {<br /> $objPHPExcel->getActiveSheet()->SetCellValue($captions[$j].$i, $_v);<br /> $j++;<br /> }<br /> if ($i <= $count)<br /> {<br /> $i ++;<br /> }<br /> }<br /><br /> // Rename sheet<br /> $objPHPExcel->getActiveSheet()->setTitle($title);<br /><br /> // Save Excel 2007 file<br /> $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);<br /><br /> header('Pragma:public');<br /> header("Content-Type:application/x-msexecl;name=\"{$filename}.xls\"");<br /> header("Content-Disposition:inline;filename=\"{$filename}.xls\"");<br /><br /> $objWriter->save('php://output');<br /> <br /> }
下面是最终的解决方案,也是非常实用的数据导出方案
/**<br /> * @DESC 数据导<br /> * @notice 解决了上面导出列数过多的问题<br /> * @example <br /> * $data = [1, '小明', '25'];<br /> * $header = ['id', '姓名', '年龄'];<br /> * Myhelpers::exportData($data, $header);<br /> * @return void, Browser direct output<br /> */<br /> public static function exportData ($data, $header, $title = 'simple', $filename = 'data')<br /> {<br /> //require relation class files<br /> require(Yii::getAlias('@common').'/components/phpexcel/PHPExcel.php');<br /> require(Yii::getAlias('@common').'/components/phpexcel/PHPExcel/Writer/Excel2007.php');<br /> <br /> if (!is_array ($data) || !is_array ($header)) return false;<br /><br /> $objPHPExcel = new \PHPExcel();<br /><br /> // Set properties<br /> $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");<br /> $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");<br /> $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");<br /> $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");<br /> $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");<br /><br /> // Add some data<br /> $objPHPExcel->setActiveSheetIndex(0);<br /><br /> //添加头部<br /> $hk = 0;<br /> foreach ($header as $k => $v)<br /> {<br /> $colum = \PHPExcel_Cell::stringFromColumnIndex($hk);<br /> $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v);<br /> $hk += 1;<br /> }<br /><br /> $column = 2;<br /> $objActSheet = $objPHPExcel->getActiveSheet();<br /> foreach($data as $key => $rows) //行写入<br /> {<br /> $span = 0;<br /> foreach($rows as $keyName => $value) // 列写入<br /> {<br /> $j = \PHPExcel_Cell::stringFromColumnIndex($span);<br /> $objActSheet->setCellValue($j.$column, $value);<br /> $span++;<br /> }<br /> $column++;<br /> }<br /><br /> // Rename sheet<br /> $objPHPExcel->getActiveSheet()->setTitle($title);<br /><br /> // Save Excel 2007 file<br /> $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);<br /><br /> header('Pragma:public');<br /> header("Content-Type:application/x-msexecl;name=\"{$filename}.xls\"");<br /> header("Content-Disposition:inline;filename=\"{$filename}.xls\"");<br /><br /> $objWriter->save('php://output');<br /> <br /> }

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











전체 가이드: PHP 확장을 사용하여 Excel 파일을 처리하는 방법 PHPExcel 소개: Excel 파일은 대용량 데이터 처리 및 통계 분석 시 데이터 저장 및 교환을 위한 일반적인 형식으로 사용되는 경우가 많습니다. PHP 확장 PHPExcel을 사용하면 Excel 파일을 쉽게 읽고, 쓰고, 수정하여 Excel 데이터를 효과적으로 처리할 수 있습니다. 이 기사에서는 PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하고 코드 예제를 제공하는 방법을 소개합니다. 1. PHPExc 설치

디지털 시대의 도래와 함께 데이터는 우리의 일상과 업무에서 가장 중요한 부분이 되었고, 엑셀 파일은 데이터 처리를 위한 중요한 도구 중 하나가 되었습니다. 나는 많은 PHP 개발자들이 직장에서 데이터 처리 및 작업을 위해 Excel 파일을 사용하는 경우를 자주 접하게 될 것이라고 생각합니다. 이 글에서는 PHPExcel 라이브러리를 사용하여 Excel 파일을 처리하는 방법과 주의사항을 소개합니다. PHPExcel이란 무엇입니까? PHPExcel은 PHP 클래스입니다.

PHPEXCEL은 Excel 파일을 읽고 쓰는 데 탁월한 PHP 클래스 라이브러리입니다. PHP를 사용하여 Excel 파일을 읽고 쓸 수 있는 매우 충분한 API를 제공합니다. 경우에 따라 사용하기 위해 Excel 파일을 CSV 파일로 변환해야 하는 경우가 있습니다. 그래서 이번 글에서는 PHPEXCEL 클래스 라이브러리를 사용하여 엑셀 파일을 CSV 파일로 변환하고 여는 방법을 주로 설명합니다.

PHPExcel은 Microsoft Excel 파일을 처리하기 위한 오픈 소스 PHP 라이브러리로 Excel 파일을 읽고, 만들고, 수정하고 저장할 수 있습니다. 데이터 분석, 보고서 생성, 데이터 가져오기 및 내보내기 등과 같은 작업을 처리하는 데 사용할 수 있는 강력하고 고도로 사용자 정의 가능한 도구입니다. 이 기사에서는 PHPExcel이 PHP 개발자의 중심이 된 이유를 소개합니다.

PHPExcel은 Microsoft Excel(.xls 및 .xlsx) 파일을 처리하기 위한 오픈 소스 PHP 라이브러리입니다. 엑셀 파일을 읽고 쓰고 조작할 수 있으며, 다양한 기능과 방법을 제공합니다. PHP 프로젝트에서 PHPExcel 라이브러리를 사용하면 Excel 파일을 빠르고 쉽게 처리하고 데이터 가져오기, 내보내기, 데이터 처리 등의 기능을 구현할 수 있습니다. 이 기사에서는 PHPExcel을 사용하여 Excel 파일을 처리하는 방법을 소개합니다. 1. PHPExcel을 설치하려면 다음을 사용하십시오.

오늘날 급속한 정보 전송 시대에 데이터 처리 및 저장은 점점 더 중요해지고 있습니다. 많은 사람들이 엑셀 테이블을 가장 먼저 선택하는 이유는 엑셀 테이블이 다양한 데이터를 통합할 수 있고 쉽게 분석하고 처리할 수 있기 때문입니다. Excel 테이블 생성을 보다 효율적으로 완료하기 위해 PHP와 PHPExcel이라는 두 가지 강력한 도구를 사용할 수 있습니다. 이번 글에서는 PHP와 PHPExcel을 사용하여 Excel 파일을 만드는 방법을 소개하겠습니다. 1. 먼저 PHPExcel을 설치하세요

PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 개요: 웹 개발에서 Excel 파일을 처리하는 것은 일반적이고 중요한 작업입니다. PHPExcel은 Excel 파일을 읽고 쓰는 데 도움이 되는 강력하고 사용하기 쉬운 PHP 라이브러리입니다. 이 기사에서는 PHPExcel 및 PHPExcel_IOFactory 라이브러리를 사용하여 MySQL 데이터베이스를 작동하는 방법을 소개합니다. 1 단계

PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 운영하는 방법 인터넷의 활발한 발전으로 인해 데이터베이스에 많은 양의 데이터가 저장되고 가져오기, 내보내기 및 처리와 같은 작업이 필요합니다. PHP 개발에서 PHPExcel은 Excel 파일과의 상호 작용을 단순화하고 데이터 가져오기 및 내보내기를 실현할 수 있는 강력한 라이브러리입니다. 이 기사에서는 PHPExcel을 사용하여 MySQL 데이터베이스를 작동하고 데이터 가져오기 및 내보내기 기능을 구현하는 방법을 소개합니다. PHPExcel 설치 및 구성
