目录
- 前言
- 使用步骤
- 1.定义类PictureData
- 2.数据集引用
- 3.定义获取excel图片数据的方法GetDTWithImg
- 总结
前言
在.net使用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插件需要自己下载。
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中的图片,将其转换成字节流存到集合中,方便后续对其进行操作。
到此这篇关于.NET使用NPOI实现读取带有图片的excel数据的文章就介绍到这了,更多相关.NET NPOI读取带图片excel数据内容请搜索悠久资源网以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源网!
您可能感兴趣的文章:
- .NET操作NPOI实现Excel的导入导出
- .net6简单使用NPOI读取Excel的项目实践
- asp.net 利用NPOI导出Excel通用类的方法
- asp.net使用npoi读取excel模板并导出下载详解
- C#使用NPOI读取excel转为DataSet
- c# 根据NPOI 读取一个excel 文件的多个Sheet