文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PHP使用PhpSpreadsheet 导出excel文件

2023-10-25 14:17

关注

        PhpSpreadsheet 是使用PHP语言编写的用户操作excel的类库,提供了一系列丰富的接口,可很方便的对文档属性、单元格进行操作,包括设置样式、图片、日期、函数等等。

PhpSpreadsheet用方法也很简单,示例如下:

一、使用PhpSpreadsheet进行excel操作,首先需要安装

composer require phpoffice/phpspreadsheet

二、引入PhpSpreadsheet类

use \PhpOffice\PhpSpreadsheet\Spreadsheet;use \PhpOffice\PhpSpreadsheet\IOFactory;use \PhpOffice\PhpSpreadsheet\Cell\Coordinate;use PhpOffice\PhpSpreadsheet\Style\Border;use PhpOffice\PhpSpreadsheet\Style\Alignment;

三、实例化PhpSpreadsheet

//实例化一个新的excel文档$newExcel = new Spreadsheet();//获取当前操作sheet的对象$objSheet = $newExcel->getActiveSheet();$date = date('Ymd',time());$name = '订单信息表';$objSheet->setTitle($name);//设置当前sheet的//设置表头$objSheet->setCellValue('A1', '单号')         ->setCellValue('B1', '时间')         ->setCellValue('C1', '联系人')         ->setCellValue('D1', '手机号')         ->setCellValue('E1', '支付金额');//设置表头样式$font = [    'font' => [        'bold' => true,        'size' => 13,     ],];$objSheet->getStyle('A1:E1')->applyFromArray($font);

四、设置表格数据

$info = [数据数组];$dataCount = count($info);$k = 1;if($dataCount == 0){    exit;}else{    for ($i=0;$i<$dataCount;$i++){        $k = $k + 1;        $objSheet->setCellValue('A' . $k, $info[$i]['order_type'])            ->setCellValue('B' . $k, $info[$i]['addtime'])            ->setCellValue('C' . $k, $info[$i]['name'])            ->setCellValue('D' . $k, $info[$i]['faren'])            ->setCellValue('E' . $k, " ".$info[$i]['shenfenzheng'])        ;        $objSheet->getStyle('A'.$k)->applyFromArray($styleArray);    }    $k = $k + 1;     $extends = $lists['extend'];    $objSheet->setCellValue('A' . $k, "这里是个合并单元格的示例");    //合并单元格    $objSheet->mergeCells('A' . $k.':E'.$k);     //最后一行样式    $objSheet->getStyle('A'.$k.':'.'A'.$k)->applyFromArray([        'font' => [            'bold' => true,            'size' => 13,            'color'=>['argb' => '000000']        ],    ]);}

五、设置表格样式

//默认行高$objSheet->getDefaultRowDimension()->setRowHeight(22);//设置宽度$objSheet->getColumnDimension('A')->setWidth(15); $objSheet->getColumnDimension('B')->setWidth(20); $objSheet->getColumnDimension('C')->setWidth(40); $objSheet->getColumnDimension('D')->setWidth(15); $objSheet->getColumnDimension('E')->setWidth(25);

六、执行保存或下载

ob_end_clean();ob_start();//设置文件扩展名, $format只能为 Xlsx 或 Xls$format='Xlsx';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="  . $name . '.' . strtolower($format));header('Cache-Control: max-age=0');$objWriter = IOFactory::createWriter($newExcel, $format);$objWriter->save('php://output');//通过php保存在服务器的时候需要用到//$objWriter->save($dir.'/demo.xlsx');exit;

以上就是Thinkphp6使用PhpSpreadsheet保存为Excel文件的使用方法 。

来源地址:https://blog.csdn.net/huafengjie/article/details/130186773

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯