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

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你需要在导出 Excel 文件中创建一个复杂的表头,可以使用 PhpOffice/PhpSpreadsheet 库中的以下方法: 1. 使用 `setMergeCells()` 方法合并单元格 使用此方法,您可以将一个或多个单元格合并成一个单元格。例如,如果您需要在表头中创建一个跨越多个列的单元格,可以将这些单元格合并成一个单元格。以下是使用此方法合并单元格的示例代码: ```php $sheet->mergeCells('A1:B1'); ``` 2. 使用 `setCellValue()` 方法设置单元格的值 使用此方法,您可以设置单元格的值。例如,在表头中,您可以使用此方法为单元格设置相应的标题。以下是使用此方法设置单元格值的示例代码: ```php $sheet->setCellValue('A1', 'Column 1'); ``` 3. 使用 `getStyle()` 方法设置单元格样式 使用此方法,您可以设置单元格的样式,例如字体、颜色、边框等。以下是使用此方法设置单元格样式的示例代码: ```php $styleArray = [ 'font' => [ 'bold' => true, 'color' => ['rgb' => 'FFFFFF'], ], 'borders' => [ 'allBorders' => [ 'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THIN, 'color' => ['rgb' => '000000'], ], ], 'fill' => [ 'fillType' => \PhpOffice\PhpSpreadsheet\Style\Fill::FILL_GRADIENT_LINEAR, 'rotation' => 90, 'startColor' => ['rgb' => 'FFA500'], 'endColor' => ['rgb' => 'FFFFFF'], ], ]; $sheet->getStyle('A1')->applyFromArray($styleArray); ``` 以上是使用 PhpOffice/PhpSpreadsheet 库创建复杂表头的基本方法,您可以根据需要进行组合和调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值