PhpSpreadsheet 读取 excel 里面的图片

2024-03-22 06:44

本文主要是介绍PhpSpreadsheet 读取 excel 里面的图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用 phpSpreadSheet 插件去读取 excel 里面的图片时发现坑点很多,这里做一个总结

我使用的是 tp 框架

一、安装 phpSpreadSheet 插件

在composer.json配置

"require": {..."phpoffice/phpspreadsheet": "*"
}

composer安装

composer require phpoffice/phpspreadsheet

二、读取图片的函数

这里会把excel里面的图片读取,然后存放到服务器指定的目录

use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Cell\Coordinate;// 获取excel表格的图片
public function main(){$imageFilePath = ROOT_PATH . 'public/uploads/images/'; //图片本地存储的路径if (!file_exists($imageFilePath)) { //如果目录不存在则递归创建mkdir($imageFilePath, 0777, true);}try {$file = ROOT_PATH . 'public/excel/2.xlsx';; //包含图片的Excel文件$objRead = IOFactory::createReader('Xlsx');$objSpreadsheet = $objRead->load($file);$objWorksheet = $objSpreadsheet->getSheet(0);$data = $objWorksheet->toArray();foreach ($objWorksheet->getDrawingCollection() as $drawing) {list($startColumn, $startRow) = Coordinate::coordinateFromString($drawing->getCoordinates());$imageFileName = $drawing->getCoordinates() . mt_rand(1000, 9999);switch ($drawing->getExtension()) {case 'jpg':case 'jpeg':$imageFileName .= '.jpg';$source = imagecreatefromjpeg($drawing->getPath());imagejpeg($source, $imageFilePath . $imageFileName);break;case 'gif':$imageFileName .= '.gif';$source = imagecreatefromgif($drawing->getPath());imagegif($source, $imageFilePath . $imageFileName);break;case 'png':$imageFileName .= '.png';$source = imagecreatefrompng($drawing->getPath());imagepng($source, $imageFilePath . $imageFileName);break;}$data[$startRow-1][$startColumn] = '/uploads/images/' . $imageFileName;}dump($data);die();} catch (\Exception $e) {throw $e;}
}

三、遇到的其他坑总结

1)解析excel遇到报错:Could not find zip member zip://文件路径.xis#_rels/.rels

解决方案:不要使用.xls格式的excel,使用.xlsx

2)使用wps上传图片时,如果是使用“嵌入到单元格”的方式上传,要在图片的右键,将图片转为浮动图片,才可以被插件解析到,因为wps会将嵌入到单元格用特殊的函数去处理:

=DISPIMG("ID_8BCFD5BECC7D4876A66B679A8D9EAC49",1)

3) 使用 CURLFile 上传图片时,如果发现 $_FILES获取不到文件,有可能是 curl 的请求头参数,不要设置成 json格式

if ($method == "post") {curl_setopt($ch, CURLOPT_POST, true);curl_setopt($ch, CURLOPT_POSTFIELDS, $post_string);//@下面这里,不要设置成json的请求头,应该屏蔽if ($header) {curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json; charset=utf-8 ','Content-Length: ' . strlen($post_string)));}
}

4)excel上传之后,获取不到excel文件,有可能是 php.ini 里面的 upload_max_filesize 比较小,然后excel里面的图片比较大,导致整个文件上传的时候,超过这个限制

这篇关于PhpSpreadsheet 读取 excel 里面的图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/834744

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

利用python实现对excel文件进行加密

《利用python实现对excel文件进行加密》由于文件内容的私密性,需要对Excel文件进行加密,保护文件以免给第三方看到,本文将以Python语言为例,和大家讲讲如何对Excel文件进行加密,感兴... 目录前言方法一:使用pywin32库(仅限Windows)方法二:使用msoffcrypto-too

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

Spring Boot读取配置文件的五种方式小结

《SpringBoot读取配置文件的五种方式小结》SpringBoot提供了灵活多样的方式来读取配置文件,这篇文章为大家介绍了5种常见的读取方式,文中的示例代码简洁易懂,大家可以根据自己的需要进... 目录1. 配置文件位置与加载顺序2. 读取配置文件的方式汇总方式一:使用 @Value 注解读取配置方式二

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)