IT俱乐部 ASP.NET .NET使用NPOI实现读取带有图片的excel数据

.NET使用NPOI实现读取带有图片的excel数据

前言

在.net使用npoi插件进行批量导入时,获取excel中的图片数据,存到集合中。

使用步骤

1.定义类PictureData

代码如下:

1
2
3
4
public class PictureData
{
    public byte[] Data { get; set; }
}

2.数据集引用

1
2
3
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel.Extensions;

npoi插件需要自己下载。

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
   /// <summary>
   /// 获取excel中图片数据
   /// </summary>
   /// 文件路径
   /// list
private List 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 picturesInColumnA = new List();
           List 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 pictureDataList = new List();
           //将图片数据放到集合中
           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数据内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/code/asp-net/10729.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部