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

首頁 > 語言 > PHP > 正文

Yii2框架中使用PHPExcel導出Excel文件的示例

2024-05-04 23:59:17
字體:
來源:轉載
供稿:網友

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

最簡單的利用composer安裝

composer require "phpoffice/phpexcel": "*"

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

1、引入PHPExcel

首先得要下載phpexcel地址:https://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->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,并提示下載或打開。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 崇明县| 长兴县| 休宁县| 噶尔县| 天峻县| 巫溪县| 安陆市| 葵青区| 玉龙| 贵溪市| 江西省| 襄汾县| 曲靖市| 绥阳县| 察哈| 民勤县| 锡林浩特市| 株洲市| 阳泉市| 福州市| 新民市| 深水埗区| 东港市| 永州市| 东乡| 徐水县| 大理市| 朔州市| 康定县| 临夏市| 灵山县| 景洪市| 嘉峪关市| 元谋县| 诏安县| 大连市| 七台河市| 宜兰县| 阳泉市| 宜兰县| 宜兰县|