Yii框架中使用PHPExcel导出Excel文件_PHP教程

php中文网
发布: 2016-07-13 10:31:47
原创
902人浏览过

 最近在研究php的yii框架,很喜欢,碰到导出excel的问题,研究了一下,就有了下面的方法:

 

立即学习PHP免费学习笔记(深入)”;

白果AI论文
白果AI论文

论文AI生成学术工具,真实文献,免费不限次生成论文大纲 10 秒生成逻辑框架,10 分钟产出初稿,智能适配 80+学科。支持嵌入图表公式与合规文献引用

白果AI论文 61
查看详情 白果AI论文

1、首先在config\main.php中添加对PHPExcel的引用,我的方式是这样:

1 2 3 4 5 6 7 8 // autoloading model and component classes     'import'=>array(                         'application.models.*',         'application.components.*',         'application.extensions.phpexcel.*',                  ),

另外也有人用components 这个配置,但是我的有问题,所以就用上面的方法。

 

立即学习PHP免费学习笔记(深入)”;

2、按照下面的代码修改PHPExcel代码目录里的Autoloader.php文件:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 public static function Register() {         $functions = spl_autoload_functions();             foreach $functions as  $function)                 spl_autoload_unregister($function);             $functions array_merge(array(array('PHPExcel_Autoloader','Load')),$functions);             foreach $functions as $function)                 $x = spl_autoload_register($function);             return $x;          }    //    function Register()

上面的函数中,注释掉的是原有的代码。

 

立即学习PHP免费学习笔记(深入)”;

3、下面的代码是输出Excel,以及一些常用的属性设置,在你的controller中:

     

    public  function actionExport()     {         $objectPHPExcel new PHPExcel();         $objectPHPExcel->setActiveSheetIndex(0);              $page_size = 52;         //数据的取出         $model = Yii::app()->session['printdata'];              $dataProvider $model->search();              $dataProvider->setPagination(false);         $data $dataProvider->getData();         $count $dataProvider->getTotalItemCount();         //总页数的算出         $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 );         $objectPHPE

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/761580.htmlTechArticle最近在研究PHP的Yii框架,很喜欢,碰到导出Excel的问题,研究了一下,就有了下面的方法: 1、首先在config\main.php中添加对PHPExcel的引用,我...
WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号