大佬教程收集整理的这篇文章主要介绍了Yii2框架中使用PHPExcel导出Excel文件的示例,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
最近在研究php的Yii框架,很喜欢,碰到导出Excel的问题,研究了一下,就有了下面的方法:
最简单的利用composer安装
1、引入phpExcel
首先得要下载phpexcel地址:https://github.com/PHPOffice/PHPExcel/archive/1.8.1.zip
你可以直接在入口文件index.php中引入,也可以在你定义的controller类之前,只要是在你使用之前引入就可以
或者在phpexcel类里修改相应的namespace也可。
2、按照下面的代码修改phpExcel代码目录里的Autoloader.php文件,对比源文件改成:
上面的函数中,注释掉的是原有的代码。
3、下面的代码是输出Excel,以及一些常用的属性设置,在controller中:
$page_size = 52;
$model = new NewsSearch();
$dataProvider = $model->search();
$dataProvider->setPagination(false);
$data = $dataProvider->getData();
$count = $dataProvider->get@R_581_10586@lItemCount();
$page_count = (int)($count/$page_sizE) +1;
$current_page = 0;
$n = 0;
foreach ( $data as $product )
{
if ( $n % $page_size === 0 )
{
$current_page = $current_page +1;
//报表头的输出
$objectphpExcel->getActiveSheet()->mergeCells('B1:G1');
$objectphpExcel->getActiveSheet()->setCellValue('B1','产品信息表');
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('B2','产品信息表');
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('B2','产品信息表');
$objectphpExcel->setActiveSheeTindex(0)->getStyle('B1')->getFont()->setSize(24);
$objectphpExcel->setActiveSheeTindex(0)->getStyle('B1')
->getAlignment()->setHorizontal(phpExcel_Style_Alignment::HORIZONTAL_CENTER);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('B2','日期:'.date("Y年m月j日"));
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('G2','第'.$current_page.'/'.$page_count.'页');
$objectphpExcel->setActiveSheeTindex(0)->getStyle('G2')
->getAlignment()->setHorizontal(phpExcel_Style_Alignment::HORIZONTAL_RIGHT);
//表格头的输出
$objectphpExcel->getActiveSheet()->getcolumnDimension('A')->setWidth(5);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('B3','编号');
$objectphpExcel->getActiveSheet()->getcolumnDimension('B')->setWidth(6.5);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('C3','名称');
$objectphpExcel->getActiveSheet()->getcolumnDimension('C')->setWidth(17);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('D3','生产厂家');
$objectphpExcel->getActiveSheet()->getcolumnDimension('D')->setWidth(22);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('E3','单位');
$objectphpExcel->getActiveSheet()->getcolumnDimension('E')->setWidth(15);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('F3','单价');
$objectphpExcel->getActiveSheet()->getcolumnDimension('F')->setWidth(15);
$objectphpExcel->setActiveSheeTindex(0)->setCellValue('G3','在库数');
$objectphpExcel->getActiveSheet()->getcolumnDimension('G')->setWidth(15);
//设置居中
$objectphpExcel->getActiveSheet()->getStyle('B3:G3')
->getAlignment()->setHorizontal(phpExcel_Style_Alignment::HORIZONTAL_CENTER);
//设置边框
$objectphpExcel->getActiveSheet()->getStyle('B3:G3' )
->getBorders()->getTop()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B3:G3' )
->getBorders()->getLeft()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B3:G3' )
->getBorders()->getright()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B3:G3' )
->getBorders()->getBottom()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B3:G3' )
->getBorders()->getVertical()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
//设置颜色
$objectphpExcel->getActiveSheet()->getStyle('B3:G3')->getFill()
->setFillType(phpExcel_Style_Fill::FILL_SOLID)->getStartColor()->setARGB('FF66CCCC');
}
//明细的输出
$objectphpExcel->getActiveSheet()->setCellValue('B'.($n+4),$product->id);
$objectphpExcel->getActiveSheet()->setCellValue('C'.($n+4),$product->product_name);
$objectphpExcel->getActiveSheet()->setCellValue('D'.($n+4),$product->product_agent->Name);
$objectphpExcel->getActiveSheet()->setCellValue('E'.($n+4),$product->unit);
$objectphpExcel->getActiveSheet()->setCellValue('F'.($n+4),$product->unit_pricE);
$objectphpExcel->getActiveSheet()->setCellValue('G'.($n+4),$product->library_count);
//设置边框
$currentRowNum = $n+4;
$objectphpExcel->getActiveSheet()->getStyle('B'.($n+4).':G'.$currentRowNum )
->getBorders()->getTop()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B'.($n+4).':G'.$currentRowNum )
->getBorders()->getLeft()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B'.($n+4).':G'.$currentRowNum )
->getBorders()->getright()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B'.($n+4).':G'.$currentRowNum )
->getBorders()->getBottom()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$objectphpExcel->getActiveSheet()->getStyle('B'.($n+4).':G'.$currentRowNum )
->getBorders()->getVertical()->setBorderstyle(phpExcel_Style_Border::BORDER_THIN);
$n = $n +1;
}
//设置分页显示
//$objectphpExcel->getActiveSheet()->setBreak( 'I55',phpExcel_Worksheet::BREAK_ROW );
//$objectphpExcel->getActiveSheet()->setBreak( 'I10',phpExcel_Worksheet::BREAK_columN );
$objectphpExcel->getActiveSheet()->getPageSetup()->setHorizontalCentered(true);
$objectphpExcel->getActiveSheet()->getPageSetup()->setVerticalCentered(false);
ob_end_clean();
ob_start();
header('Content-Type : application/vnd.ms-excel');
header('Content-Disposition:attachment;filename="'.'产品信息表-'.date("Y年m月j日").'.xls"');
$objWriter= phpExcel_IOFactory::createWriter($objectphpExcel,'Excel5');
$objWriter->save('php://output');
代码执行后,会直接生成Excel,并提示下载或打开。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持菜鸟教程。
以上是大佬教程为你收集整理的Yii2框架中使用PHPExcel导出Excel文件的示例全部内容,希望文章能够帮你解决Yii2框架中使用PHPExcel导出Excel文件的示例所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。