当前位置:首页 > PHP教程 > php高级应用 > 列表

PHP实现生成Excel文件并导出的示例详解

发布:smiling 来源: PHP粉丝网  添加日期:2023-06-24 18:11:08 浏览: 评论:0 

在现在的项目里,不管是电商项目还是别的项目,在管理端都会有导出的功能,比方说订单表导出,用户表导出,业绩表导出。这些都需要提前生成excel表,然后在导出,实际上是在代码里生成一张excel表,然后通过下载api进行导出的。好了 先给大家讲一下示例。

利用php导出excel我们大多会直接生成.xls文件,这种方便快捷。

首先我们先在项目中引入几个类

  1. use \PhpOffice\PhpSpreadsheet\Spreadsheet; 
  2. use \PhpOffice\PhpSpreadsheet\IOFactory; 
  3. use \PhpOffice\PhpSpreadsheet\Cell\Coordinate; 
  4. use PhpOffice\PhpSpreadsheet\Style\Border; 
  5. use PhpOffice\PhpSpreadsheet\Style\Alignment; 

然后我们在进行封装一个生成并导出excel表的方法,这里我们用订单表做示例

  1. //订单信息导出excel 
  2.     public function order_outputProjectExcel($info){ 
  3.         $newExcel = new Spreadsheet();//创建一个新的excel文档 
  4.         $objSheet = $newExcel->getActiveSheet();//获取当前操作sheet的对象 
  5.         $date = date('Ymd',time()); 
  6.         $name = '订单信息表'
  7.         $objSheet->setTitle($name);//设置当前sheet的标题 
  8.    
  9.         //样式设置 - 合并和拆分 
  10.         $objSheet->mergeCells('A1:P1'); //合并单元格 
  11.         //$sheet -> unmergeCells('C3:G3'); //拆分单元格 
  12.         $objSheet->setCellValue('A1',$name); 
  13.    
  14.         //设置第一栏的中文标题 
  15.         $objSheet->setCellValue('A2''编号'
  16.             ->setCellValue('B2''商品图片'
  17.             ->setCellValue('C2''商品名称'
  18.             ->setCellValue('D2''会员编号'
  19.             ->setCellValue('E2''直属'
  20.             ->setCellValue('F2''非直属'
  21.             ->setCellValue('G2''订单号'
  22.             ->setCellValue('H2''商品单价'
  23.             ->setCellValue('I2''实付金额'
  24.             ->setCellValue('J2''商品佣金'
  25.             ->setCellValue('K2''会员佣金'
  26.             ->setCellValue('L2''直属佣金'
  27.             ->setCellValue('M2''非直属佣金'
  28.             ->setCellValue('N2''支付时间'
  29.             ->setCellValue('O2''支付渠道'
  30.             ->setCellValue('P2''订单状态'); 
  31.    
  32.         //写入数据 
  33.         $dataCount = count($info); 
  34.         $k = 2; 
  35.           
  36.         if($dataCount == 0){ 
  37.             exit
  38.         }else
  39.             for ($i=0;$i<$dataCount;$i++){ 
  40.                 $k = $k + 1; 
  41.                 $order=$i+1; 
  42.                 $objSheet->setCellValue('A' . $k$info[$i]['id']) 
  43.                     ->setCellValue('B' . $k$info[$i]['goods_image']) 
  44.                     ->setCellValue('C' . $k$info[$i]['goods_name']) 
  45.                     ->setCellValue('D' . $k$info[$i]['user_num']) 
  46.                     ->setCellValue('E' . $k$info[$i]['user_upteam']) 
  47.                     ->setCellValue('F' . $k$info[$i]['user_un_upteam']) 
  48.                     ->setCellValue('G' . $k$info[$i]['order_id']) 
  49.                     ->setCellValue('H' . $k$info[$i]['goods_price']) 
  50.                     ->setCellValue('I' . $k$info[$i]['payment']) 
  51.                     ->setCellValue('J' . $k$info[$i]['goods_yongjin']) 
  52.                     ->setCellValue('K' . $k$info[$i]['user_yongjin']) 
  53.                     ->setCellValue('L' . $k$info[$i]['user_up_yongjin']) 
  54.                     ->setCellValue('M' . $k$info[$i]['user_un_upyongjin']) 
  55.                     ->setCellValue('N' . $k$info[$i]['paymenttime']) 
  56.                     ->setCellValue('O' . $k$info[$i]['pay_way_ch']) 
  57.                     ->setCellValue('P' . $k$info[$i]['status_ch']); 
  58.             } 
  59.         } 
  60.    
  61.         //设定样式 
  62.         //所有sheet的表头样式 加粗 
  63.         $font = [ 
  64.             'font' => [ 
  65.                 'bold' => true, 
  66.                 'size' => 14, 
  67.             ], 
  68.         ]; 
  69.         $objSheet->getStyle('A1:P1')->applyFromArray($font); 
  70.    
  71.         //样式设置 - 水平、垂直居中 
  72.         $styleArray = [ 
  73.             'alignment' => [ 
  74.                 'horizontal' => Alignment::HORIZONTAL_CENTER, 
  75.                 'vertical' => Alignment::VERTICAL_CENTER 
  76.             ], 
  77.         ]; 
  78.         $objSheet->getStyle('A1:P2')->applyFromArray($styleArray); 
  79.    
  80.         //所有sheet的内容样式-加黑色边框 
  81.         $borders = [ 
  82.             'borders' => [ 
  83.                 'outline' => [ 
  84.                     'borderStyle' => Border::BORDER_THIN, 
  85.                     'color' => ['argb' => '000000'], 
  86.                 ], 
  87.                 'inside' => [ 
  88.                     'borderStyle' => Border::BORDER_THIN, 
  89.                 ] 
  90.             ], 
  91.         ]; 
  92.         $objSheet->getStyle('A1:P'.$k)->applyFromArray($borders); 
  93.    
  94.         //设置宽度 
  95.         $cell = ['A''B''C''D''E''F''G''H''I''J''K''L''M''N''O''P']; 
  96.         foreach($cell as $k=>$v){ 
  97.             $objSheet->getColumnDimension($v)->setWidth(20); 
  98.    
  99. //            $objSheet->getColumnDimension($v)->setAutoSize(true); 
  100.         } 
  101.    
  102.         $this->downloadExcel($newExcel,$name,'Xlsx'); 
  103.     }
  104.       
  105.     //下载 
  106.     private function downloadExcel($newExcel,$filename,$format
  107.     { 
  108.         ob_end_clean(); 
  109.         ob_start(); 
  110.         // $format只能为 Xlsx 或 Xls 
  111.         if ($format == 'Xlsx') { 
  112.             header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); 
  113.         } elseif ($format == 'Xls') { 
  114.             header('Content-Type: application/vnd.ms-excel'); 
  115.         } 
  116. //  strtolower($format) 
  117.         header("Content-Disposition: attachment;filename=" 
  118.             . $filename . '.' . strtolower($format)); 
  119.         header('Cache-Control: max-age=0'); 
  120.         $objWriter = IOFactory::createWriter($newExcel$format); 
  121.         $objWriter->save('php://output'); 
  122.  
  123.         //通过php保存在本地的时候需要用到 
  124.         // $objWriter->save($dir.'/demo.xlsx'); 
  125.    
  126.         //以下为需要用到IE时候设置 
  127.         // If you're serving to IE 9, then the following may be needed 
  128.         //header('Cache-Control: max-age=1'); 
  129.         // If you're serving to IE over SSL, then the following may be needed 
  130.         //header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past 
  131.         //header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified 
  132.         //header('Cache-Control: cache, must-revalidate'); // HTTP/1.1 
  133.         //header('Pragma: public'); // HTTP/1.0 
  134.         exit
  135.     } 

到这一步其实就已经成功了95%了。剩下的5%只需要你调用上面的方法传入正确的参数即可。

model('Apimodel')->order_outputProjectExcel($info);

这里的$info是你的订单详情。必须要做时间筛选,如果不做时间筛选的话 数据量一多,你的系统会崩的。

这里的for循环就是你传入的 $info,如果说你的 $info 是空的 那么导出的excel打开的时候还会出现。

PHP实现生成Excel文件并导出的示例详解

  1. for ($i=0;$i<$dataCount;$i++){ 
  2.     $k = $k + 1; 
  3.     $order=$i+1; 
  4.     $objSheet->setCellValue('A' . $k$info[$i]['id']) 
  5.         ->setCellValue('B' . $k$info[$i]['goods_image']) 
  6.         ->setCellValue('C' . $k$info[$i]['goods_name']) 
  7.         ->setCellValue('D' . $k$info[$i]['user_num']) 
  8.         ->setCellValue('E' . $k$info[$i]['user_upteam']) 
  9.         ->setCellValue('F' . $k$info[$i]['user_un_upteam']) 
  10.         ->setCellValue('G' . $k$info[$i]['order_id']) 
  11.         ->setCellValue('H' . $k$info[$i]['goods_price']) 
  12.         ->setCellValue('I' . $k$info[$i]['payment']) 
  13.         ->setCellValue('J' . $k$info[$i]['goods_yongjin']) 
  14.         ->setCellValue('K' . $k$info[$i]['user_yongjin']) 
  15.         ->setCellValue('L' . $k$info[$i]['user_up_yongjin']) 
  16.         ->setCellValue('M' . $k$info[$i]['user_un_upyongjin']) 
  17.         ->setCellValue('N' . $k$info[$i]['paymenttime']) 
  18.         ->setCellValue('O' . $k$info[$i]['pay_way_ch']) 
  19.         ->setCellValue('P' . $k$info[$i]['status_ch']); 
  20.   } 

最后就是这样的效果

PHP实现生成Excel文件并导出的示例详解

Tags: PHP生成Excel PHP导出Excel

分享到: