php使用PhpSpreadsheet导出excel

1. 下载安装,

2. 大致包括: 单元格拆分, 单元格合并, 字体样式, 单元内容垂直居中, 边框样式, 单元格宽度设置等; 代码如下所示:

<?php
//引用composer自动加载文件
require $_SERVER['DOCUMENT_ROOT'].'/standard/vendor/autoload.php';
//引用phpspreadsheet类库
use \PhpOffice\PhpSpreadsheet\Spreadsheet;
use \PhpOffice\PhpSpreadsheet\IOFactory;
use \PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use PhpOffice\PhpSpreadsheet\Style\Border;
use PhpOffice\PhpSpreadsheet\Style\Alignment;

class EXCEL 
{
	public static $excel;
	
    public static function getInstance(){
        if(!isset(self::$excel)){
            self::$excel = new self();
        }
        return self::$excel;
    }
	
    private function __construct(){
		//require './PHPExcel/Classes/PHPExcel.php';
		//require './PHPExcel/Classes/PHPExcel/IOFactory.php';
	}
	
    //禁止外部克隆
    private function __clone(){

    }
    
	//下载
	private function downloadExcel($newExcel, $filename, $format)
	{
		// $format只能为 Xlsx 或 Xls
        if ($format == 'Xlsx') {
            header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        } elseif ($format == 'Xls') {
            header('Content-Type: application/vnd.ms-excel');
        }

        header("Content-Disposition: attachment;filename="
            . $filename . date('Ymdhis') . '.' . strtolower($format));
        header('Cache-Control: max-age=0');
        $objWriter = IOFactory::createWriter($newExcel, $format);

        $objWriter->save('php://output');

        //通过php保存在本地的时候需要用到
        //$objWriter->save($dir.'/demo.xlsx');

        //以下为需要用到IE时候设置
        // If you're serving to IE 9, then the following may be needed
        //header('Cache-Control: max-age=1');
        // If you're serving to IE over SSL, then the following may be needed
        //header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
        //header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
        //header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
        //header('Pragma: public'); // HTTP/1.0
        exit;
	}

	//读取excel, 支持一个excel中多张工作表, 要求格式为第一行名称,第二行开始数据
	public function getExcel($files){
        $reader = IOFactory::createReader('Xlsx');
        $reader->setReadDataOnly(TRUE);
        $spreadsheet = $reader->load($files);

        $arr = [];
        //一个excel多个工作表,循环读取
        foreach ($spreadsheet->getWorksheetIterator() as $k=> $worksheet) {
            //工作表的名称
            $worksheetTitle = $worksheet->getTitle();
            $arr[$k]['title']=$worksheetTitle;
            //获取行数,返回的是数字
            $highestRow = $worksheet->getHighestRow();
            //获取列数,返回的是字母
            $highestColumn = $worksheet->getHighestColumn();
            //列数字母索引转数字
            $highestColumnIndex = Coordinate::columnIndexFromString($highestColumn);
            $data = [];
            for($i=2;$i<=$highestRow;$i++){
                for ($j=1;$j<=$highestColumnIndex;$j++){
                    $data[$i][$j]= $worksheet->getCellByColumnAndRow($j, $i)->getValue();
                }
            }

            $arr[$k]['data']=$data;
        }

        return $arr;
    }


    //项目商务信息导出excel
    public function outputProjectExcel($info){
        $newExcel = new Spreadsheet();//创建一个新的excel文档
        $objSheet = $newExcel->getActiveSheet();//获取当前操作sheet的对象
        $date = date('Ymd',time());
        $name = '项目商务信息'.$date;
        $objSheet->setTitle($name);//设置当前sheet的标题

        //样式设置 - 合并和拆分
        $objSheet->mergeCells('A1:N1'); //合并单元格
        //$sheet -> unmergeCells('C3:G3'); //拆分单元格
        $objSheet->setCellValue('A1',$name);

        //设置第一栏的中文标题
        $objSheet->setCellValue('A2', '序号')
            ->setCellValue('B2', '项目名称')
            ->setCellValue('C2', '区域')
            ->setCellValue('D2', '类型')
            ->setCellValue('E2', '项目面积')
            ->setCellValue('F2', '安装情况')
            ->setCellValue('G2', '实施公司')
            ->setCellValue('H2', '合同金额')
            ->setCellValue('I2', '评估')
            ->setCellValue('J2', '目标计划')
            ->setCellValue('K2', '项目动态进度')
            ->setCellValue('L2', '联系人')
            ->setCellValue('M2', '商务负责人')
            ->setCellValue('N2', '技术负责人');

        //写入数据
        $dataCount = count($info);
        $k = 2;
        if($dataCount == 0){
            exit;
        }else{
            for ($i=0;$i<$dataCount;$i++){
                $k = $k + 1;
                $order=$i+1;
                $objSheet->setCellValue('A' . $k, $order)
                    ->setCellValue('B' . $k, $info[$i]['project_name'])
                    ->setCellValue('C' . $k, $info[$i]['name'])
                    ->setCellValue('D' . $k, $info[$i]['type_name'])
                    ->setCellValue('E' . $k, $info[$i]['built_area'])
                    ->setCellValue('F' . $k, $info[$i]['installation_progress'])
                    ->setCellValue('G' . $k, $info[$i]['construction_unit'])
                    ->setCellValue('H' . $k, $info[$i]['project_money'])
                    ->setCellValue('I' . $k, $info[$i]['estimate'])
                    ->setCellValue('J' . $k, $info[$i]['target'])
                    ->setCellValue('K' . $k, $info[$i]['trends'])
                    ->setCellValue('L' . $k, $info[$i]['contacts'])
                    ->setCellValue('M' . $k, $info[$i]['business_director'])
                    ->setCellValue('N' . $k, $info[$i]['technical_director']);
            }
        }

        //设定样式
        //所有sheet的表头样式 加粗
        $font = [
            'font' => [
                'bold' => true,
                'size' => 20,
            ],
        ];
        $objSheet->getStyle('A1:N1')->applyFromArray($font);

        //样式设置 - 水平、垂直居中
        $styleArray = [
            'alignment' => [
                'horizontal' => Alignment::HORIZONTAL_CENTER,
                'vertical' => Alignment::VERTICAL_CENTER
            ],
        ];
        $objSheet->getStyle('A1:N2')->applyFromArray($styleArray);

        //所有sheet的内容样式-加黑色边框
        $borders = [
            'borders' => [
                'outline' => [
                    'borderStyle' => Border::BORDER_THIN,
                    'color' => ['argb' => '000000'],
                ],
                'inside' => [
                    'borderStyle' => Border::BORDER_THIN,
                ]
            ],
        ];
        $objSheet->getStyle('A1:N'.$k)->applyFromArray($borders);

        //设置宽度
        $cell = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N'];
        foreach($cell as $k=>$v){
            $objSheet->getColumnDimension($v)->setWidth(20);

//            $objSheet->getColumnDimension($v)->setAutoSize(true);
        }

        $this->downloadExcel($newExcel, $name, 'Xls');
    }
	
}

$excel = EXCEL::getInstance(null);
?>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用PhpSpreadsheet导出Excel文件,你可以按照以下步骤进行操作: 1. 首先,实例化一个Spreadsheet对象,例如: ```php use PhpOffice\PhpSpreadsheet\Spreadsheet; $spreadsheet = new Spreadsheet(); ``` \[1\] 2. 接下来,设置文件的扩展名和格式,以及设置相应的HTTP头信息,例如: ```php $format = 'Xlsx'; // 设置文件格式为Xlsx或Xls if ($format == 'Xlsx') { header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); } elseif ($format == 'Xls') { header('Content-Type: application/vnd.ms-excel'); } $name = 'example'; // 设置文件名 header("Content-Disposition: attachment;filename=" . $name . '.' . strtolower($format)); header('Cache-Control: max-age=0'); ``` \[2\] 3. 创建一个Writer对象,并将Spreadsheet对象保存到输出流中,例如: ```php use PhpOffice\PhpSpreadsheet\IOFactory; $objWriter = IOFactory::createWriter($spreadsheet, $format); $objWriter->save('php://output'); ``` \[2\] 这样,你就可以通过PhpSpreadsheet导出Excel文件了。记得在保存文件之后使用`exit`函数来终止脚本的执行。 如果你想导出为xls文件,可以按照以下步骤进行操作: 1. 设置相应的HTTP头信息,例如: ```php header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); ``` \[3\] 2. 设置文件名和缓存控制,例如: ```php $filename = date('Y-m-d').'工作报告单'; header('Content-Disposition: attachment;filename='.$filename .'.xls'); header('Cache-Control:max-age=0'); ``` \[3\] 3. 创建一个Writer对象,并将Spreadsheet对象保存到输出流中,例如: ```php $write = IOFactory::createWriter($spreadsheet, 'Xls'); $write->save('php://output'); ``` \[3\] 这样,你就可以使用PhpSpreadsheet导出xls文件了。记得在保存文件之后使用`exit`函数来终止脚本的执行。 #### 引用[.reference_title] - *1* *3* [php使用PhpSpreadsheet导出Excel表格详解](https://blog.csdn.net/weixin_44888397/article/details/131484139)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [PHP使用PhpSpreadsheet 导出excel文件](https://blog.csdn.net/huafengjie/article/details/130186773)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值