phpoffice/phpspreadsheet导出数据常用方法

本篇:phpoffice导出数据常用方法

本次内容使用composer安装phpoffice/phpspreadsheet

composer require phpoffice/phpspreadsheet
  1. 逐行写入数据
  2. 批量写入数据
  3. 优化手段

逐行插入数据:

<?php
    //引入加载文件
    require_once 'vendor/autoload.php';

     // 创建一个新的Spreadsheet对象
    $spreadsheet = new PhpOffice\PhpSpreadsheet\Spreadsheet();
    // 获取活动的工作表
    $sheet = $spreadsheet->getActiveSheet();

    $header=['姓名','年龄'];//头部标题
    //设置头部标题
    foreach ($header as $i => $Htitle) {
        $column_cell = 'A'.($i+1);
        // 设置头部标题
        $sheet->setCellValue($column_cell, $Htitle);
    }
    //示例数据,视业务而定
    $data=[
        [
            "name"=>"张三",
            "age"=>18
        ],
        [
            "name"=>"李四",
            "age"=>20
        ]
    ];
    $num = 2; //从第二行开始填充数据
    foreach ($data as $i => $row) {
        $row_cell = $num + $i;
        // 设置单元格内容
        $sheet->setCellValue('A'.$row_cell, $row['name']);
        $sheet->setCellValue('B'.$row_cell, $row['age']);
    }

    // // 获取单元格样式对象
    // $style = $sheet->getStyle('A1');

    // // 获取并设置对齐方式
    // $alignment = $style->getAlignment();
    // $alignment->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_LEFT);

    // // 应用样式
    // $style->setAlignment($alignment);

    // 导出或保存文件
    $writer = new PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet);
    $writer->setUseDiskCaching(true);//启动磁盘缓存
    $writer->setIncludeCharts(false);//关闭图表
    $writer->setPreCalculateFormulas(false);//关闭公式预计算
    $writer->save('example.xlsx');//保存文件路径需使用绝对路径
?>

批量插入数据:

<?php
    //引入加载文件
    require_once 'vendor/autoload.php';

     // 创建一个新的Spreadsheet对象
    $spreadsheet = new PhpOffice\PhpSpreadsheet\Spreadsheet();
    // 获取活动的工作表
    $sheet = $spreadsheet->getActiveSheet();
    //示例数据
    $data = [
        ['姓名', '年龄', '城市'],
        ['张三', 25, '北京'],
        ['李四', 30, '上海'],
        ['王五', 28, '广州'],
    ];//填充数据应为二维数组
    $sheet->fromArray($data, null, "A1");//从A1单元格开始填充
    // 导出或保存文件
    $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');//使用工厂方法IOFactory::createWriter可创建导出不同格式的Excel文件  
    $writer->save('example.xlsx');//保存文件路径需使用绝对路径
?>

优化手段

  1. 分批处理数据: 不要一次性加载所有数据到内存中,尤其是数据量很大时。可以使用分页或分批加载数据,逐步写入Excel文件。
  2. 设置使用磁盘缓存: 在保存之前使用$writer->setUseDiskCaching(true),优化内存的使用和性能;
  3. 减少内存占用: 使用$writer->setPreCalculateFormulas(false),关闭公式预计算,减少内存占用。
  4. 减少内存占用: 使用$writer->setIncludeCharts(false),关闭图表,减少内存占用。
  5. 使用流式写入: 对于大量数据,考虑使用流式写入(streamed writing),例如使用PhpSpreadsheet 中的 PhpOffice\PhpSpreadsheet\Writer\Xlsx 类。

本篇博客地址:Github Pages

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值