使用 PHP 和 PhpSpreadsheet 在 Excel 中插入图片(附完整代码)

2025-12-12 0 355

在现代 Web 开发中,经常需要生成包含数据和图片的 Excel 报表。本文将介绍如何使用 PHP 和 PhpOfficePhpSpreadsheet 库创建一个包含图片的 Excel 文件。

准备工作

首先需要安装 PhpSpreadsheet 库:

composer require phpoffice/phpspreadsheet

核心实现

1. 创建图片插入函数

function addImageToCell($worksheet, $imagePath, $cell, $name)
{
    $drawing = new Drawing();
    $drawing->setName($name);
    $drawing->setDescription($name);
    $drawing->setPath($imagePath);
    $drawing->setHeight(80);
    $drawing->setWidth(100);
    $drawing->setCoordinates($cell);
    $drawing->setOffsetX(5);
    $drawing->setOffsetY(5);
    $drawing->setWorksheet($worksheet);
}

这个函数使用 PhpOfficePhpSpreadsheetWorksheetDrawing 类来处理图片插入,设置了图片的尺寸、位置和偏移量。

2. 准备数据

$header = [\'课程名称\', \'图片\'];
$list = [
    [
        \'name\' => \'thinkphp\',
        \'image\' => \'images/thinkphp.png\'
    ],
    [
        \'name\' => \'npm\',
        \'image\' => \'images/npm.png\'
    ],
    [
        \'name\' => \'uni-app\',
        \'image\' => \'images/uni-app.jpg\'
    ]
];

3. 创建 Excel 并填充数据

$spreadsheet = new Spreadsheet();
$worksheet = $spreadsheet->getActiveSheet();
​
// 填充标题行
$worksheet->setCellValue(\'A1\', $header[0]);
$worksheet->setCellValue(\'B1\', $header[1]);
$worksheet->getColumnDimension(\'B\')->setWidth(15);
​
$line = 1;
foreach ($list as $k => $v) {
    $line++;
    $worksheet->getRowDimension($line)->setRowHeight(100);
    $worksheet->getCell(\'A\' . $line)->setValue($v[\'name\']);
    addImageToCell($worksheet, $v[\'image\'], \'B\' . $line, $v[\'name\']);
}

4. 保存文件

通过命令行保存文件:php index.php

$writer = new Xlsx($spreadsheet);
$filename = \'course_list.xlsx\';
$writer->save($filename);

通过站点保存文件:php -S 127.0.0.1:8888,访问127.0.0.1:8888可直接触发下载。也可以通过Ngnix等部署成站点,访问下载

header(\'Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\');
header(\'Content-Disposition: attachment;filename=\"course_list.xlsx\"\');
header(\'Cache-Control: max-age=0\');
​
$writer = new Xlsx($spreadsheet);
$writer->save(\'php://output\');

关键要点

  • 使用 Drawing 类处理图片插入
  • 设置合适的行高和列宽以适应图片
  • 使用 setOffsetXsetOffsetY 调整图片在单元格中的位置
  • 确保图片路径正确且文件存在

实际效果

生成的 Excel 文件将包含两列:课程名称和对应的图片,每张图片都会整齐地显示在单元格中,具有良好的视觉效果。

这种方法非常适合生成产品目录、员工信息表、课程列表等需要同时展示文本信息和图片的报表。

完整代码

<?php
require __DIR__ . \'/vendor/autoload.php\';
​
use PhpOfficePhpSpreadsheetSpreadsheet;
use PhpOfficePhpSpreadsheetWorksheetDrawing;
use PhpOfficePhpSpreadsheetWriterXlsx;
​
function addImageToCell($worksheet, $imagePath, $cell, $name)
{
    $drawing = new Drawing();
    $drawing->setName($name);
    $drawing->setDescription($name);
    $drawing->setPath($imagePath);
    $drawing->setHeight(80);
    $drawing->setWidth(100);
    $drawing->setCoordinates($cell);
    $drawing->setOffsetX(5);
    $drawing->setOffsetY(5);
    $drawing->setWorksheet($worksheet);
}
​
// 示例数据
$header = [\'课程名称\', \'图片\'];
$list = [
    [
        \'name\' => \'thinkphp\',
        \'image\' => \'images/thinkphp.png\'
    ],
    [
        \'name\' => \'npm\',
        \'image\' => \'images/npm.png\'
    ],
    [
        \'name\' => \'uni-app\',
        \'image\' => \'images/uni-app.jpg\'
    ]
];
​
$spreadsheet = new Spreadsheet();
$worksheet = $spreadsheet->getActiveSheet();
​
// 填充标题行
$worksheet->setCellValue(\'A1\', $header[0]);
$worksheet->setCellValue(\'B1\', $header[1]);
$worksheet->getColumnDimension(\'B\')->setWidth(15);
$line = 1;
foreach ($list as $k => $v) {
    $line++;
    $worksheet->getRowDimension($line)->setRowHeight(100);
    $worksheet->getCell(\'A\' . $line)->setValue($v[\'name\']);
    addImageToCell($worksheet, $v[\'image\'], \'B\' . $line, $v[\'name\']);
}
​
// 保存为 Excel 文件
$writer = new Xlsx($spreadsheet);
$filename = \'course_list.xlsx\';
$writer->save($filename);
​
// 下载 Excel 文件
// header(\'Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\');
// header(\'Content-Disposition: attachment;filename=\"course_list.xlsx\"\');
// header(\'Cache-Control: max-age=0\');
// $writer = new Xlsx($spreadsheet);
// $writer->save(\'php://output\');

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

申明:本文由第三方发布,内容仅代表作者观点,与本网站无关。对本文以及其中全部或者部分内容的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。本网发布或转载文章出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,也不代表本网对其真实性负责。

左子网 编程相关 使用 PHP 和 PhpSpreadsheet 在 Excel 中插入图片(附完整代码) https://www.zuozi.net/35887.html

常见问题
  • 1、自动:拍下后,点击(下载)链接即可下载;2、手动:拍下后,联系卖家发放即可或者联系官方找开发者发货。
查看详情
  • 1、源码默认交易周期:手动发货商品为1-3天,并且用户付款金额将会进入平台担保直到交易完成或者3-7天即可发放,如遇纠纷无限期延长收款金额直至纠纷解决或者退款!;
查看详情
  • 1、描述:源码描述(含标题)与实际源码不一致的(例:货不对板); 2、演示:有演示站时,与实际源码小于95%一致的(但描述中有”不保证完全一样、有变化的可能性”类似显著声明的除外); 3、发货:不发货可无理由退款; 4、安装:免费提供安装服务的源码但卖家不履行的; 5、收费:价格虚标,额外收取其他费用的(但描述中有显著声明或双方交易前有商定的除外); 6、其他:如质量方面的硬性常规问题BUG等。 注:经核实符合上述任一,均支持退款,但卖家予以积极解决问题则除外。
查看详情
  • 1、左子会对双方交易的过程及交易商品的快照进行永久存档,以确保交易的真实、有效、安全! 2、左子无法对如“永久包更新”、“永久技术支持”等类似交易之后的商家承诺做担保,请买家自行鉴别; 3、在源码同时有网站演示与图片演示,且站演与图演不一致时,默认按图演作为纠纷评判依据(特别声明或有商定除外); 4、在没有”无任何正当退款依据”的前提下,商品写有”一旦售出,概不支持退款”等类似的声明,视为无效声明; 5、在未拍下前,双方在QQ上所商定的交易内容,亦可成为纠纷评判依据(商定与描述冲突时,商定为准); 6、因聊天记录可作为纠纷评判依据,故双方联系时,只与对方在左子上所留的QQ、手机号沟通,以防对方不承认自我承诺。 7、虽然交易产生纠纷的几率很小,但一定要保留如聊天记录、手机短信等这样的重要信息,以防产生纠纷时便于左子介入快速处理。
查看详情

相关文章

猜你喜欢
发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务