.NetCore 使用 NPOI 读取带有图片的excel数据

在.NetCore使用NPOI插件进行批量导入时,获取Excel中的所有的图片数据,存到集合中。

1.定义类PictureData

代码如下:

public class PictureData

{

public byte[] Data { get; set; }

}

2.数据集引用

using NPOI.XSSF.UserModel;

using NPOI.SS.UserModel;

using NPOI.XSSF.UserModel.Extensions;

npoi插件可以通过nuget安装或自己下载引用。

3.定义获取excel图片数据的方法GetDTWithImg

/// <summary>

/// 获取excel中图片数据

/// </summary>

/// <param name="path">文件路径</param>

/// <returns>list</returns>

private List<PictureData> GetDTWithImg(string path)

{

using (FileStream file = new FileStream(path, FileMode.Open, FileAccess.Read))

{

IWorkbook workbook = null;

ISheet sheet = null;

workbook = WorkbookFactory.Create(file);

sheet = workbook.GetSheet("Sheet1");

if (sheet == null)

{

sheet = workbook.GetSheetAt(0);

}

// 获取绘图对象

XSSFDrawing drawing = (XSSFDrawing)sheet.CreateDrawingPatriarch();

List<XSSFPicture> picturesInColumnA = new List<XSSFPicture>();

List<XSSFShape> shapes = drawing.GetShapes();

foreach (XSSFShape shape in shapes)

{

if (shape is XSSFPicture)

{

XSSFPicture picture = (XSSFPicture)shape;

XSSFClientAnchor anchor = (XSSFClientAnchor)picture.GetPreferredSize();

picturesInColumnA.Add(picture);

}

}

List<PictureData> pictureDataList = new List<PictureData>();

//将图片数据放到集合中

foreach (XSSFPicture picture in picturesInColumnA)

{

byte[] pictureData = picture.PictureData.Data;

PictureData data = new PictureData

{

Data = pictureData

};

pictureDataList.Add(data);

}

return pictureDataList;

}

}

通过该方法可以获取excel中的图片,将其转换成字节流存到集合中,方便后续对其进行操作。

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

相关推荐
Access开发易登软件17 小时前
在 Access 实现标签输入控件:VBA + HTML 混合开发实战
前端·数据库·信息可视化·html·excel·vba·access
胡斌附体18 小时前
配置导入事务问题与修复总结
excel·导入·spring事务·吞异常·使用独立事务
王夏奇19 小时前
Python-对excel文件操作的总览
开发语言·python·excel
林月明19 小时前
【Coze基础】Excel保存CSV文件时其设置为UTF-8编码,将数据导入数据库中
数据库·sql·oracle·excel·code·学习经验
howard200519 小时前
Pandas读取包含多个工作表的Excel文件
excel·pandas
Dylan~~~19 小时前
Excel MCP Server:用自然语言操控 Excel,开启“对话式电子表格“新时代
excel·ai编程
猹叉叉(学习版)19 小时前
【ASP.NET CORE】 12. DDD基本概念
笔记·后端·架构·c#·asp.net·.netcore
catoop20 小时前
Excel 实战技巧:利用 OFFSET 统计 “标识行” 下方的数值总和
excel
江沉晚呤时20 小时前
C# 接口默认实现与依赖注入实战指南:.NET 9 企业级开发高级技巧
c#·log4j·.net·.netcore
SHolmes18542 天前
Excel 公式解析:按条件去重计数
excel