如何使用PHPExcel从excel文件中读取图像并将图像保存在服务器中并显示它们?该文件的扩展名为.xlsx.
我的代码:
$objPHPExcel = PHPExcel_IOFactory::load($path);
foreach ($objPHPExcel->getActiveSheet()->getDrawingCollection() as $drawing) {
if ($drawing instanceof PHPExcel_Worksheet_MemoryDrawing) {
ob_start();
call_user_func(
$drawing->getRenderingFunction(),
$drawing->getImageResource()
);
$imageContents = ob_get_contents();
ob_end_clean();
}
}
Run Code Online (Sandbox Code Playgroud)
谢谢!!
$objPHPExcel->getActiveSheet()->getDrawingCollection()
Run Code Online (Sandbox Code Playgroud)
将返回活动工作表中所有图像对象的ArrayObject.
这些对象可以是PHPExcel_Worksheet_Drawing或PHPExcel_Worksheet_MemoryDrawing对象:您可以使用[is_a()] [1]来识别哪些对象.然后,您可以使用适合该类的方法(如API中所述)从文件(对于PHPExcel_Worksheet_Drawing对象)读取图像数据,或直接从PHPExcel_Worksheet_MemoryDrawing对象本身读取.getName()和getDescription()方法可用于检索图像对象的相关值.
请注意,也可以将图像对象与打印标题相关联:
$objPHPExcel->getActiveSheet()->getHeaderFooter()->getImages()
Run Code Online (Sandbox Code Playgroud)
可用于从页眉/页脚中检索图像.这是一个PHPExcel_Worksheet_HeaderFooterDrawing对象的数组.所有PHPExcel_Worksheet_Drawing方法都可用于从这些对象中提取图像文件.
编辑
喂食时间.
这将从当前活动的工作表中提取所有图像,并将它们写入服务器上的文件.
$objPHPExcel = PHPExcel_IOFactory::load($path);
$i = 0;
foreach ($objPHPExcel->getActiveSheet()->getDrawingCollection() as $drawing) {
if ($drawing instanceof PHPExcel_Worksheet_MemoryDrawing) {
ob_start();
call_user_func(
$drawing->getRenderingFunction(),
$drawing->getImageResource()
);
$imageContents = ob_get_contents();
ob_end_clean();
switch ($drawing->getMimeType()) {
case PHPExcel_Worksheet_MemoryDrawing::MIMETYPE_PNG :
$extension = 'png'; break;
case PHPExcel_Worksheet_MemoryDrawing::MIMETYPE_GIF:
$extension = 'gif'; break;
case PHPExcel_Worksheet_MemoryDrawing::MIMETYPE_JPEG :
$extension = 'jpg'; break;
}
} else {
$zipReader = fopen($drawing->getPath(),'r');
$imageContents = '';
while (!feof($zipReader)) {
$imageContents .= fread($zipReader,1024);
}
fclose($zipReader);
$extension = $drawing->getExtension();
}
$myFileName = '00_Image_'.++$i.'.'.$extension;
file_put_contents($myFileName,$imageContents);
}
Run Code Online (Sandbox Code Playgroud)
文件已命名
00_Image_n.extension
Run Code Online (Sandbox Code Playgroud)
其中n是从1开始的数字,扩展名是图像类型的适当扩展名(png,jpg,gif,等等).
| 归档时间: |
|
| 查看次数: |
5542 次 |
| 最近记录: |