PHP phpoffice/phpspreadsheet导出excel

PHP phpoffice/phpspreadsheet导出excel

由于PHPExcel已经被废弃在PHP7.2中已经无法获取更新,官方重新开了一个新包phpspreadsheet
注意:这里使用的是tp6框架做测试

第一步:使用composer在根项目下安装phpspreadsheet
安装命令:composer require phpoffice/phpspreadsheet
安装成功后,会在vendor目录下成一个目录:phpoffice
PHP phpoffice/phpspreadsheet导出excel_第1张图片
第二步:后端代码处理
注意:顶部引入第三方类库
use PhpOffice\PhpSpreadsheet\Spreadsheet;
PHP phpoffice/phpspreadsheet导出excel_第2张图片

- 代码:
/*

  /*
    * 数据处理
    */
    public function derive()
    {
        //需导出的数据,多条数据
        $data = [
            [
                'time' => '时间',
                'order_num' => '付款人数',
                'did' => '付款订单数',
                'total_price' => '付款金额',
                'good_num' => '付款件数'
            ],
            [
                'time' => '时间',
                'order_num' => '付款人数',
                'did' => '付款订单数',
                'total_price' => '付款金额',
                'good_num' => '付款件数'
            ]
        ];
        $xlsName = "测试" . date("YmdHis", time());//文件名称
        $head = ['日期', '付款人数', '付款订单数', '付款金额', '付款件数'];// 表头信息
        //表字段和表头信息一一对应
        $keys = ['time', 'order_num', 'did', 'total_price', 'good_num'];
        $this->downloadExcel($xlsName, $data, $head, $keys);// 传递参数

    }
 /*
     * 导出数据
     */
    public function downloadExcel($name, $data = [], $head = [], $keys = [])
    {
        $count = count($head);  //计算表头数量
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();

        for ($i = 65; $i < $count + 65; $i++) {     //数字转字母从65开始,循环设置表头:
            $sheet->setCellValue(strtoupper(chr($i)) . '1', $head[$i - 65]);
        }
        //循环设置单元格:
        foreach ($data as $key => $item) {
            //$key+2,因为第一行是表头,所以写到表格时   从第二行开始写
            for ($i = 65; $i < $count + 65; $i++) {
                //数字转字母从65开始:
                $sheet->setCellValue(strtoupper(chr($i)) . ($key + 2), $item[$keys[$i - 65]]);
                //固定列宽
                $spreadsheet->getActiveSheet()->getColumnDimension(strtoupper(chr($i)))->setWidth(20);
            }

        }
         $names = $name;
        //utf-8转unicode格式
        $name = iconv('UTF-8', 'UCS-2BE', $name);
        $len = strlen($name);

        $str = '';

        for ($i = 0; $i < $len - 1; $i = $i + 2) {

            $c = $name[$i];

            $c2 = $name[$i + 1];

            if (ord($c) > 0) {

                $str .= '\u' . base_convert(ord($c), 10, 16) . str_pad(base_convert(ord($c2), 10, 16), 2, 0, STR_PAD_LEFT);

            } else {

                $str .= '\u' . str_pad(base_convert(ord($c2), 10, 16), 4, 0, STR_PAD_LEFT);

            }

        }

//        header('Content-Type: application/vnd.ms-excel');
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');

        header('Data-Type: binary');
        //前端导出数据根据这个unicode格式解析为中文
        header('Data-Filename: ' . $str);
        header('Content-Disposition: attachment;filename="' . $names . '.xlsx"');
        header('Cache-Control: max-age=0');
        header('Access-Control-Expose-Headers:Data-Type,Data-Filename');
       
        //header('Content-Type: application/vnd.ms-excel');
        //header('Content-Disposition: attachment;filename="' . $name . '.xlsx"');
        //header('Cache-Control: max-age=0');
        $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
        $writer->save('php://output');
        exit;

    }

设置Excel表格样式

$sheet = $spreadsheet->getActiveSheet();


 // 合并单元格
$sheet->mergeCells('A1:L1');
  
// 设置单元格值
$sheet->setCellValue('A1',$value);
  
//设值行高
$sheet->getRowDimension('1')->setRowHeight(16);
  
//设置表头信息字体大小
$sheet->getCell('A1')->getStyle()->getFont()->setSize(12);
  
//设置所有字体
$spreadsheet->getDefaultStyle()->getFont()->setName('微软雅黑');
  
//设置水平默认对齐方式
$spreadsheet->getDefaultStyle()->getAlignment()
   ->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
   
//设置垂直默认对齐方式
$spreadsheet->getDefaultStyle()->getAlignment()
	   ->setVertical(\PhpOffice\PhpSpreadsheet\Style\Alignment::VERTICAL_CENTER);
//设置外边框和内边框
$styleArray = [
			   'borders' => [
				   'outline' => [
					   'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THICK,
				   ],
				   'inside' =>[
					   'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN,
				   ]
			   ],
		   ];

$sheet->getStyle('A1:L20')->applyFromArray($styleArray);
//设置列宽
$spreadsheet->getActiveSheet()->getColumnDimension('H')->setWidth(14);
   
//设置单元格为文本格式
$sheet->getCell('A'.$row)->getStyle()->getNumberFormat()->setFormatCode(NumberFormat::FORMAT_TEXT);

//新增一个sheet
$sheet = $spreadsheet->createSheet();
//设置字体颜色
$sheet->getCell("B$startRow")->getStyle()->getFont()
                    ->getColor()->setARGB(\PhpOffice\PhpSpreadsheet\Style\Color::COLOR_RED);
 //字体加粗
    $sheet->getCell("A$startRow")->getStyle()->getFont()->setBold(true);                   
//设置单元格背景色
   $spreadsheet->getActiveSheet()->getStyle($column .($beginRow))->getFill()
                        ->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID)
                        ->getStartColor()->setARGB('FF9800');
//设置公式
$sheet->setCellValue(
                        "C1",
                        "=SUM(F1:F10)"
                    );
                   
		
		
		
		
		

到这PHP 使用phpoffice/phpspreadsheet导出excel就完成了,后需可以根据自己业务需要做对应的调整

你可能感兴趣的:(学习经验,excel)