国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

如何實(shí)現(xiàn)Yii2框架中使用PHPExcel導(dǎo)出Excel文件

2020-03-22 18:01:51
字體:
供稿:網(wǎng)友
本篇文章主要介紹了Yii2框架中使用PHPExcel導(dǎo)出Excel文件的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

?最近在研究PHP的html' target='_blank'>Yii框架,很喜歡,碰到導(dǎo)出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類里修改相應(yīng)的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;}

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

3、下面的代碼是輸出Excel,以及一些常用的屬性設(shè)置,在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; //報(bào)表頭的輸出 $objectPHPExcel- getActiveSheet()- mergeCells( B1:G1  $objectPHPExcel- getActiveSheet()- setCellValue( B1 , 產(chǎn)品信息表  $objectPHPExcel- setActiveSheetIndex(0)- setCellValue( B2 , 產(chǎn)品信息表  $objectPHPExcel- setActiveSheetIndex(0)- setCellValue( B2 , 產(chǎn)品信息表  $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 , 生產(chǎn)廠家  $objectPHPExcel- getActiveSheet()- getColumnDimension( D )- setWidth(22); $objectPHPExcel- setActiveSheetIndex(0)- setCellValue( E3 , 單位  $objectPHPExcel- getActiveSheet()- getColumnDimension( E )- setWidth(15); $objectPHPExcel- setActiveSheetIndex(0)- setCellValue( F3 , 單價(jià)  $objectPHPExcel- getActiveSheet()- getColumnDimension( F )- setWidth(15); $objectPHPExcel- setActiveSheetIndex(0)- setCellValue( G3 , 在庫數(shù)  $objectPHPExcel- getActiveSheet()- getColumnDimension( G )- setWidth(15); //設(shè)置居中 $objectPHPExcel- getActiveSheet()- getStyle( B3:G3 ) - getAlignment()- setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //設(shè)置邊框 $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); //設(shè)置顏色 $objectPHPExcel- getActiveSheet()- getStyle( B3:G3 )- getFill() - setFillType(PHPExcel_Style_Fill::FILL_SOLID)- getStartColor()- setARGB( FF66CCCC  //明細(xì)的輸出 $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); //設(shè)置邊框 $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;  //設(shè)置分頁顯示 //$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= . 產(chǎn)品信息表- .date( Y年m月j日 ). .xls $objWriter= PHPExcel_IOFactory::createWriter($objectPHPExcel, Excel5 $objWriter- save( php://output

代碼執(zhí)行后,會直接生成Excel,并提示下載或打開。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,更多相關(guān)內(nèi)容請關(guān)注PHP !

相關(guān)推薦:

YII 表單驗(yàn)證規(guī)則大全,yii表單規(guī)則大全

以上就是如何實(shí)現(xiàn)Yii2框架中使用PHPExcel導(dǎo)出Excel文件的詳細(xì)內(nèi)容,PHP教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 玉龙| 隆子县| 蒙阴县| 监利县| 环江| 临沧市| 玉田县| 潍坊市| 嵊州市| 法库县| 黎平县| 柳州市| 柯坪县| 通渭县| 措美县| 榕江县| 河池市| 江油市| 平远县| 聂荣县| 资源县| 南陵县| 礼泉县| 休宁县| 鹿邑县| 吉木萨尔县| 安庆市| 长白| 崇左市| 长春市| 东辽县| 淳化县| 顺平县| 宁武县| 长乐市| 赤水市| 临澧县| 义马市| 濮阳市| 大田县| 乐东|