使用PhpOffice\PhpSpreadsheet 实现Excel多sheet导出代码

2024-09-19实例代码
221

使用PhpOffice\PhpSpreadsheet 实现Excel多sheet导出代码,具体代码如下:


require "vendor/autoload.php";
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Reader\Xlsx as ReaderXlsx;
use PhpOffice\PhpSpreadsheet\IOFactory;

  /**
     * 多sheet的导出
     * @author bwy <xxx@xxx.com>
     * @param [type] $data_array
     * @return void
     */
    public  function xtexport($data_array)
    { 
        $name = '团长' . date("Y-m-d", time());
        $spreadsheet = new Spreadsheet();
        foreach ($data_array as $key => $data) {
            $this->opSheet($spreadsheet,$key,$data);
        }
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="' . $name . '.xlsx"');
        header('Cache-Control: max-age=0');
        $writer = new Xlsx($spreadsheet);
        $writer->save('php://output');
        //删除清空:
        $spreadsheet->disconnectWorksheets();
        unset($spreadsheet);
        exit;
    }



/**
     * 处理多sheet
     * @author bwy <xxx@xxx.com>
     * @param [type] $spreadsheet
     * @param [type] $n
     * @param [type] $data
     * @return void
     */
    public  function opSheet($spreadsheet,$n, $data)
    {
        $spreadsheet->createSheet();//创建sheet
        $objActSheet = $spreadsheet->setActiveSheetIndex($n);//设置当前的活动sheet
        $keys = $data['rows'][0];//这是你的数据键名
        $count = count($keys);//计算你所占的列数
        $infoNum = ceil(count($data['info']) / 2);//求k-v值的所占行数
        $infoStart = $infoNum + 2 ;//下面的详细信息的开始行数
        $cellName    = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');
        $sheet = $spreadsheet->getActiveSheet($n)->setTitle($data['info']['社区团长姓名:']);//设置sheet的名称
        $spreadsheet->getActiveSheet($n)->mergeCells('A1:' . $cellName[$count - 1] . '1'); //合并单元格
        $spreadsheet->getActiveSheet($n)->getStyle('A1')->getFont()->setSize(20); //设置title的字体大小
        $spreadsheet->getActiveSheet($n)->getStyle('A1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('A')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('B')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('C')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('D')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('E')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('F')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('G')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart")->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart")->getFont()->setBold(true); //标题栏加粗
        $objActSheet->setCellValue('A1', $data['title']); //设置每个sheet中的名称title


        /**
         * 图中最下面的数据信息循环
         */
        foreach ($data['rows'] as $key => $item) 
        {             
            //循环设置单元格:
            //$key+$infoStart,因为第一行是表头,所以写到表格时   从第数据行开始写 
            for ($i = 65; $i < $count + 65; $i++) 
            {   
                //数字转字母从65开始:
                //$sheet->setCellValue(strtoupper(chr($i)) . ($key + "$infoStart"), $item[[$keys][$i - 65]]);
                $sheet->setCellValue(strtoupper(chr($i)) . ($key+"$infoStart"), $item[$i - 65]);
                $spreadsheet->getActiveSheet($n)->getColumnDimension(strtoupper(chr($i)))->setWidth(20); //固定列宽
            }
        }

        /**
         * 处理图中的中间区 团长名称之类的 
         */
        $rowNumber = 1;
        $infoIndex = 0;
        foreach ($data['info'] as $key => $value) {
            if ($infoIndex % 2 == 0) {
                $rowNumber++;
                $infoCellName1 = 'A' . $rowNumber;
                $infoCellMegreRange = 'B' . $rowNumber . ':C' . $rowNumber;
                $infoCellName2 = 'B' . $rowNumber;
            } else {
                $infoCellName1 = 'D' . $rowNumber;
                $infoCellMegreRange = 'E' . $rowNumber . ':F' . $rowNumber;
                $infoCellName2 = 'E' . $rowNumber;
            }
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName1, $key);
            $spreadsheet->getActiveSheet($n)->mergeCells($infoCellMegreRange);
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName2, $value);
            $infoIndex++;
        }
    }

public function xtexport()
    {
        $data = array(
            array(
                'title' => 'AAA',
                'info' => [
                    '社区团长店铺地址:' => 'AAA',
                    '社区团长姓名:' => 'AAA',
                    '收货地址:' => 'AAA',
                    '联系方式:' => 'AAA',
                    '配送日期:' => 'AAA',
                    '手打阿达:' => 'AAA',
                    '手动蝶阀:' => 'AAA'
                ],
                'rows' => [
                    [
                        'id',
                        'name',
                        'sex',
                        'phone',
                        'res',
                        'aaa',
                        'bbb'
                    ],
                    [
                        1111,2222,3333,4444,5555,6666,7777
                    ],
                    [
                        111,222,333,444,555,666,777
                    ]
                ]
            ), array(
                'title' => 'BBBB',
                'info' => [
                    '社区团长店铺地址:' => 'BBBB',
                    '社区团长姓名:' => 'BBBB',
                    '收货地址:' => 'BBBB',
                    '联系方式:' => 'BBBB',
                    '配送日期:' => 'BBBB',
                    '手打阿达:' => 'BBBB',
                    '手动蝶阀:' => 'BBBB'
                ],
                'rows' => [
                    [
                        'id',
                        'name',
                        'sex',
                        'phone',
                        'res',
                        'aaa',
                        'bbb'
                    ],
                    [
                        1,2,3,4,5,6,7
                    ],
                    [
                        11,22,33,44,55,66,77
                    ]
                ]
            )
        );
        model('Excel')->xtexport($data);
    }
The End

相关推荐

layui下拉多选框xm-select.js插件的使用
创建容器 xm-select-demo,选择容器 隐藏赋值取值表单; div id="selected_box" class="layui-input-inline xm-select-demo" style="width:150px;"input type="hidden" id="poi_category_id"/div 异步获取代码 //获取分类; $.ajax({ type: 'get', url: "./ap...
2024-12-23 实例代码
99

php使用curl模拟post传输文件的实例代码
文件发送的代码如下: ?$url = 'http://127.0.0.1/fujian/jieshou.php'; // 目标URL$filePath2 = iconv("utf-8","gb2312",'D:/MYOA/webroot/fujian/1/副本.txt'); // 文件路$filePath1 = iconv("utf-8","gb2312",'D:/MYOA/webroot/fujian/1/1.txt'); // 文件...
2024-11-01 实例代码
212

使用PhpSpreadsheet导入&导出Excel
PHP对Excel导入导出操作 最近公司要做报表功能,各种财务报表、工资报表、考勤报表等,于是特地封装适用各大场景的导入导出操作,希望大神支出不足之处。 phpspreadsheet 引入 由于PHPExcel早就停止更新维护,所以适用phpspreadsheet。不知道如何通过composer...
2024-09-22 实例代码
161

使用PhpOffice\PhpSpreadsheet 实现Excel多sheet导出代码
使用PhpOffice\PhpSpreadsheet 实现Excel多sheet导出代码,具体代码如下: /** * 多sheet的导出 * @author bwy xxx@xxx.com * @param [type] $data_array * @return void */ public function xtexport($data_array) { $name = '团长' . date("Y-m-d", time())...
2024-09-19 实例代码
221

PhpSpreadsheet导入导出excel实例代码
首先安装PhpSpreadsheet composer require phpoffice/phpspreadsheet 导入导出代码入下: use PhpOffice\PhpSpreadsheet\Spreadsheet;use PhpOffice\PhpSpreadsheet\Writer\Xlsx;use PhpOffice\PhpSpreadsheet\Reader\Xlsx as ReaderXlsx;use PhpOffice\PhpSp...
2024-09-19 实例代码
189

layui使用tips鼠标悬停提示语的实例代码
layui使用tips鼠标悬停提示语的实例代码,具体代码如下,有三种方式: !DOCTYPE htmlhtml lang="zh" head meta charset="UTF-8" title测试-liu 劉/title/headscript src="https://cdn.staticfile.org/layui/2.7.6/layui.js"/scriptscript src="https://code.j...
2024-08-02 实例代码
258