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

 更新时间:2024年03月28日 09:15:01   作者:Zmi粒  
这篇文章主要为大家详细介绍了.NET如何使用NPOI实现读取带有图片的excel数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

前言

在.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版)

    解析微信支付的实现方法(.NET版)

    由于微信的广泛利用,基于微信开发的一系列也应运而生,这篇文章主要介绍了解析微信支付的实现方法(.NET版),有兴趣的可以了解一下。
    2016-11-11
  • 详解ASP.NET Core WebApi 返回统一格式参数

    详解ASP.NET Core WebApi 返回统一格式参数

    这篇文章主要介绍了详解ASP.NET Core WebApi 返回统一格式参数,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • Asp.Net Core基于JWT认证的数据接口网关实例代码

    Asp.Net Core基于JWT认证的数据接口网关实例代码

    这篇文章主要给大家介绍了关于Asp.Net Core基于JWT认证的数据接口网关的相关资料,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者使用Asp.net Core具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • Asp.Net Core利用文件监视进行快速测试开发详解

    Asp.Net Core利用文件监视进行快速测试开发详解

    这篇文章主要给大家介绍了关于Asp.Net Core利用文件监视进行快速测试开发的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-12-12
  • asp.net自定义控件回发数据实现方案与代码

    asp.net自定义控件回发数据实现方案与代码

    在实现asp.net的自定义控件中,若要实现数据的回发或者post数据,那自义控件必须实现IPostBackDataHandler接口, 在该接口中有两个方法一个是LoadPostData,另一个是RaisePostDataChangedEvent,需要的朋友可以了解下
    2012-12-12
  • 详解.NET Core+Docker 开发微服务

    详解.NET Core+Docker 开发微服务

    这篇文章给大家分享了.NET Core+Docker 开发微服务的相关知识点内容,有兴趣的朋友们参考下。
    2018-09-09
  • asp.net实现负载均衡

    asp.net实现负载均衡

    本文给大家分享的是asp.net实现负载均衡的方案,是个人的一些经验总结,有需要的小伙伴可以参考下
    2016-01-01
  • .NET Core实现简单的Redis Client框架

    .NET Core实现简单的Redis Client框架

    本文详细讲解了.NET Core实现简单的Redis Client框架,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Visual Studio 2022智能辅助编码介绍

    Visual Studio 2022智能辅助编码介绍

    这篇文章介绍了Visual Studio 2022智能辅助编码,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • ASP.NET Core MVC学习之视图组件(View Component)

    ASP.NET Core MVC学习之视图组件(View Component)

    这篇文章主要给大家介绍了关于ASP.NET Core MVC学习之视图组件(View Component)的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用ASP.NET Core MVC具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08

最新评论