Laravel使用PhpOffice\PhpSpreadsheet多sheet数据导出(2)

Laravel使用PhpOffice\PhpSpreadsheet多sheet数据导出(包含图片导出)

导出的示例

处理下载


    use PhpOffice\PhpSpreadsheet\Spreadsheet;
    use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
        
    public function exportPost($id)
    {
        //处理数据
        $exportData = $this->dealExposrData($id);

        $name = '申请表' . date("Y-m-d", time());
        $spreadsheet = new Spreadsheet();
        foreach ($exportData 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;
    }

excel样式

public  function opSheet($spreadsheet,$n, $data)
    {
        $spreadsheet->createSheet();//创建sheet
        $objActSheet = $spreadsheet->setActiveSheetIndex($n);//设置当前的活动sheet

        // 学习经历
        $keys = $data['college'][0];//这是你的数据键名
        $count = count($keys);//计算你所占的列数
        $infoNum = ceil(count($data['info']) / 3);//求k-v值的所占行数
        $infoStart = $infoNum + 2 ;//下面的详细信息的开始行数

        // 社团同学习经历
        // 工作经历同学习经历
        // 获奖同学习经历

        // 自我介绍
        $infoStart_introduction = $infoStart_prize + $count_prize;
        // 证书
        $infoStart_certificate = $infoStart_introduction + 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的名称
        // 标题
        $objActSheet->setCellValue('A1', $data['title']); 
        $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_introduction")->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER); 
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart_certificate")->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER); 
        //标题栏加粗
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart")->getFont()->setBold(true); 
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart_introduction")->getFont()->setBold(true); 
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart_certificate")->getFont()->setBold(true); 
        //设置每个sheet中的名称title
        $objActSheet->setCellValue(strtoupper(chr(65)) . ("$infoStart"), '大学经历');
        $objActSheet->setCellValue(strtoupper(chr(65)) . ("$infoStart_introduction"), '自我介绍');
        $objActSheet->setCellValue(strtoupper(chr(65)) . ("$infoStart_certificate"), '证书');
        // 合并单元格
        $spreadsheet->getActiveSheet($n)->mergeCells(strtoupper(chr(65)) . $infoStart.':' . $cellName[$count - 1] . $infoStart);
        $spreadsheet->getActiveSheet($n)->mergeCells(strtoupper(chr(65)) . $infoStart_introduction.':' . $cellName[$count - 1] . $infoStart_introduction); 
        $spreadsheet->getActiveSheet($n)->mergeCells(strtoupper(chr(65)) . $infoStart_certificate.':' . $cellName[$count - 1] . $infoStart_certificate); 
        // 设置字体大小
        $spreadsheet->getActiveSheet($n)->getStyle(strtoupper(chr(65)) . $infoStart)->getFont()->setSize(15);
        $spreadsheet->getActiveSheet($n)->getStyle(strtoupper(chr(65)) . $infoStart_introduction)->getFont()->setSize(15);
        $spreadsheet->getActiveSheet($n)->getStyle(strtoupper(chr(65)) . $infoStart_certificate)->getFont()->setSize(15);
       

        // 学习经历数据循环
        foreach ($data['college'] as $key => $item) 
        {             
            //循环设置单元格:$key+$infoStart,因为第一行是表头,所以写到表格时   从第数据行开始写 
            for ($i = 65; $i < $count + 65; $i++)  {   
                //数字转字母从65开始:
                $sheet->setCellValue(strtoupper(chr($i)) . ($key+1+"$infoStart"), $item[$i - 65]);
                $spreadsheet->getActiveSheet($n)->getColumnDimension(strtoupper(chr($i)))->setWidth(20);
            }
        }
      
        // 自我介绍
        $sheet->setCellValue(strtoupper(chr(65)) . ("$infoStart_introduction"+1), $data['introduction']);
        $spreadsheet->getActiveSheet($n)->getColumnDimension(strtoupper(chr(65)))->setWidth(20); //固定列宽
        $spreadsheet->getActiveSheet($n)->mergeCells(strtoupper(chr(65)) . ("$infoStart_introduction" +1).':' . $cellName[$count - 1] . ("$infoStart_introduction"+1)); 

        // 证书-多图片下载
        $certificateNum = 0;
        foreach ($data['certificate'] as $k=>$img) {
            if ($img != '') {
                $drawing[$k] = new \PhpOffice\PhpSpreadsheet\Worksheet\Drawing();
                $drawing[$k]->setName('图片');
                $drawing[$k]->setDescription('图片');
                $drawing[$k]->setPath(public_path($img));
                $drawing[$k]->setWidth(80);
                $drawing[$k]->setHeight(80);
                $drawing[$k]->setCoordinates(strtoupper(chr(65+$certificateNum)) .(1+"$infoStart_certificate"));
                $drawing[$k]->setOffsetX(12);
                $drawing[$k]->setOffsetY(12);
                $drawing[$k]->setWorksheet($spreadsheet->getActiveSheet());
                $certificateNum++;
            }
        }
        // 处理基本信息之类的 
        $rowNumber = 1;
        $infoIndex = 0;
        foreach ($data['info'] as $key => $value) {
            if ($infoIndex % 3 == 0) {
                $rowNumber++;
                $infoCellName1 = 'A' . $rowNumber;
                $infoCellName2 = 'B' . $rowNumber;
            } elseif ($infoIndex % 3 == 1) {
                $infoCellName1 = 'C' . $rowNumber;
                $infoCellName2 = 'D' . $rowNumber;
            } else {
                $infoCellName1 = 'E' . $rowNumber;
                $infoCellName2 = 'F' . $rowNumber;
            }
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName1, $key);
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName2, $value);
            $infoIndex++;
        }
    }

数据格式

public  function dealExposrData($id) {
  $exportData =[
   0=>[
        "title" => "XX公司招聘申请表"
        "introduction" => "诚实正直、。。。。。。。。。。。。。。。。。。。。"
        "info" => array:22 [
            "姓名" => "XX"
            "性别" => "X"
            "年龄" => "22"
            "民族" => "汉族"
            "籍贯" => "XX省XX县"
            "生源地" => "XX省XX市"
            "政治面貌" => "共青团员"
            "身高体重" => "182/75"
            "身份证号" => "111111111111111"
            "健康状态" => "健康"
            "婚育状态" => "未婚"
            "总和排名" => ""
            "外语证书" => "四级"
            "计算机证" => "计算机一级 "
            "资格资质" => ""
            "电话" => "13000000000"
            "紧急电话" => "13900000000"
            "电子邮箱" => "xxxx@163.com"
            "应聘岗位" => "xxx工程师"
            "现居地" => "XX省XX市"
            "学籍验证码" => "xxxxxxxx"
            "兴趣爱好" => "跑步、打篮球"
          ]
          "college" => array:2 [
              0 => array:6 [
                  0 => "起止时间"
                  1 => "毕业院校"
                  2 => "专业"
                  3 => "学历"
                  4 => "学位"
                  5 => "备注"
              ]
              1 => array:6 [
                  0 => "XX年X月X日"
                  1 => "XX大学"
                  2 => "XXX"
                  3 => "本科"
                  4 => ""
                  5 => ""
              ]
            ]
            "clubLeader" => array:3 [  ]
            "jobs" => array:2 [  ]
            "family" => array:3 [ ]
            "prize" => array:3 [ ]
            "certificate" => array:15 [
                0 => "/uploads/file/2020-07-17/XXXXX.jpg"
                1 => "/uploads/file/2020-07-17/XXXXX.jpg"
            ]
        ]
   1=>[...]
   2=>[...]
]

 return $exportData;
}

完成!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,082评论 5 464
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,231评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,047评论 0 327
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,977评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,893评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,976评论 3 388
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,605评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,888评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,906评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,732评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,513评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,980评论 3 301
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,132评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,447评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,027评论 2 343
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,232评论 2 339