亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

如何實現Yii2框架中使用PHPExcel導出Excel文件

2020-03-22 18:01:51
字體:
來源:轉載
供稿:網友
本篇文章主要介紹了Yii2框架中使用PHPExcel導出Excel文件的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

?最近在研究PHP的html' target='_blank'>Yii框架,很喜歡,碰到導出Excel的問題,研究了一下,就有了下面的方法:

最簡單的利用composer安裝

composer require phpoffice/phpexcel : * 

如果沒有安裝conposer可以參考下面1.2步

1、引入PHPExcel

首先得要下載phpexcel地址:http://github.com/PHPOffice/PHPExcel/archive/1.8.1.zip

你可以直接在入口文件index.php中引入,也可以在你定義的controller類之前,只要是在你使用之前引入就可以

require dirname(dirname(__FILE__)). /excel/PHPExcel.php 

或者在phpexcel類里修改相應的namespace也可。

2、按照下面的代碼修改PHPExcel代碼目錄里的Autoloader.php文件,對比源文件改成:

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;}

上面的函數中,注釋掉的是原有的代碼。

3、下面的代碼是輸出Excel,以及一些常用的屬性設置,在controller中:

public function actionExport() $objectPHPExcel = new PHPExcel(); $objectPHPExcel- setActiveSheetIndex(0); $page_size = 52; $model = new NewsSearch(); $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-  $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);
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,并提示下載或打開。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP !

相關推薦:

YII 表單驗證規則大全,yii表單規則大全

以上就是如何實現Yii2框架中使用PHPExcel導出Excel文件的詳細內容,PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久国产精品亚洲一区| 精品免费在线观看| www.久久撸.com| 亚洲欧洲国产精品| 日韩中文字幕在线观看| 日韩国产高清污视频在线观看| 亚洲欧美国产高清va在线播| 国产精品网站视频| 成人免费网站在线| 亚洲欧美日韩综合| 欧美黑人巨大xxx极品| 日韩高清av一区二区三区| 亚洲国产成人精品久久| 国产激情综合五月久久| 26uuu日韩精品一区二区| 高清日韩电视剧大全免费播放在线观看| 久久亚洲精品成人| 亚洲色图第一页| 川上优av一区二区线观看| 成人黄色av播放免费| 国产精品久久久久久影视| 亚洲香蕉伊综合在人在线视看| 久久精品最新地址| 精品中文字幕在线| 亚洲午夜女主播在线直播| 国产精品美女www| 日韩在线观看高清| 日韩免费av一区二区| 欧美国产激情18| 国产精品18久久久久久首页狼| 久久精品视频va| 色偷偷亚洲男人天堂| 91成人在线观看国产| 91亚洲国产成人久久精品网站| 久久免费在线观看| 国产成人精品av| 亚洲mm色国产网站| 亚洲国产91精品在线观看| 色综合久综合久久综合久鬼88| 成人网在线观看| 亚洲石原莉奈一区二区在线观看| 57pao国产成人免费| 亚洲午夜未删减在线观看| 欧美一区二粉嫩精品国产一线天| 国产精品伦子伦免费视频| 久久精品视频在线观看| 国产成人综合一区二区三区| 一区二区三区四区视频| 精品女厕一区二区三区| 欧美精品在线视频观看| 日韩视频永久免费观看| 亚洲女同性videos| 欧美激情免费观看| 精品中文视频在线| 96国产粉嫩美女| 最近中文字幕2019免费| 亚洲国产精久久久久久久| 国产日韩精品一区二区| 久久久久久尹人网香蕉| 国产美女主播一区| 国产精品黄色影片导航在线观看| 亚洲成人999| 亚洲aⅴ日韩av电影在线观看| 亚洲人成毛片在线播放| 精品美女久久久久久免费| 国产日韩综合一区二区性色av| 亚洲欧美日韩中文在线| 亚洲国模精品私拍| 欧美一区二三区| 成人激情视频在线观看| 精品国产网站地址| 欧美高清激情视频| 欧美另类精品xxxx孕妇| 国产91精品久久久| 成人xxxx视频| 亚洲欧美国产日韩天堂区| 91久久精品美女高潮| 高清在线视频日韩欧美| 人妖精品videosex性欧美| 日韩在线视频网站| 中文字幕亚洲一区二区三区| 97色在线视频观看| 亚洲视频在线视频| 北条麻妃一区二区在线观看| 久久久久久欧美| 国产精品视频导航| 亚洲国产成人av在线| 国产精品美女在线观看| 久久久久国产精品一区| 亚洲jizzjizz日本少妇| 日韩欧美在线视频免费观看| 中文字幕亚洲激情| 色噜噜狠狠色综合网图区| 国产欧美亚洲精品| 日韩成人中文电影| 日韩激情在线视频| 久久成人人人人精品欧| 亚洲欧美福利视频| 成人精品久久久| 日韩欧美国产骚| 国产情人节一区| 91av在线视频观看| 欧美福利视频在线| 国产成人免费av电影| 亚洲第一精品福利| 国产欧美在线播放| 欧美激情精品久久久久久久变态| 久久久久久久久久久av| 精品视频偷偷看在线观看| 九九热这里只有精品免费看| 日韩av中文字幕在线播放| 成人免费视频在线观看超级碰| 亚洲精品国产精品国自产在线| 国产在线视频不卡| 久久久免费精品| 日产精品久久久一区二区福利| 欧美xxxx18国产| 久久人人爽人人| 97国产精品免费视频| 亚洲男人天堂古典| 日韩资源在线观看| 国产精品久久久久免费a∨大胸| 亚洲白拍色综合图区| 欧美成人精品在线视频| 国产精品极品美女粉嫩高清在线| 日韩在线播放视频| 成人妇女免费播放久久久| 国产欧美一区二区白浆黑人| **欧美日韩vr在线| 成人久久一区二区三区| 最新的欧美黄色| 久久精品视频播放| 亚洲欧美一区二区精品久久久| 国产亚洲激情在线| 岛国av在线不卡| 精品久久久久久亚洲国产300| 欧美视频一二三| 91高清在线免费观看| 日韩在线观看免费av| 亚洲欧洲黄色网| 日韩av电影免费观看高清| 精品国产91久久久| 欧美激情精品在线| 欧美日韩不卡合集视频| 91精品国产91久久久久久吃药| 国产精品男人的天堂| 亚洲va久久久噜噜噜| 日本免费一区二区三区视频观看| 国产精品偷伦视频免费观看国产| 日韩中文字幕在线看| 亚洲曰本av电影| 91在线高清免费观看| 久久99国产精品久久久久久久久| 国内精品久久久久久影视8| 国产欧美精品日韩精品| 97精品在线视频| 一本色道久久88精品综合| 国产精品极品在线| 人人爽久久涩噜噜噜网站| 久久亚洲综合国产精品99麻豆精品福利| 国产欧美在线看| 2018国产精品视频| 欧美激情欧美激情| 性色av一区二区三区|