服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C#使用NPOI导出Excel类封装

C#使用NPOI导出Excel类封装

2023-02-09 15:22武尚发的博客 C#

这篇文章主要为大家详细介绍了C#使用NPOI导出Excel类封装,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作。 NPOI是一个开源的C#读写Excel、WORD等微软OLE2组件文档的项目。

以下代码主要分3部分:通过实体类的自定义特性导出Excel文件

1、封装类:ExcelHelper
2、实体类:StudentModel
3、调用:Form1

ExcelHelper

?
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
 /// <summary>
/// Excel操作类
/// </summary>
/// <typeparam name="T">实体类</typeparam>
public class ExcelHelper<T> where T : class
    {
        /// <summary>
        /// 保存Excel文件
        /// </summary>
        /// <param name="excelName">Excel文件名</param>
        /// <param name="sheetName">Sheet工作表名</param>
        /// <param name="data">实体类对象</param>
        public static void SaveExcelFile(string excelName, string sheetName, List<T> data)
        {
 
            IWorkbook workBook = new HSSFWorkbook(); //创建一个Excel文档
            ISheet sheet = workBook.CreateSheet(sheetName); //创建一个工作表Sheet
 
 
            int rowNum = 0;
            var row = sheet.CreateRow(sheet.LastRowNum); //LastRowNum记录当前可用写入的行索引
            PropertyInfo[] preInfo = typeof(T).GetProperties();//获取这个实体对象的所有属性
            foreach (var item in preInfo)
            {
                object[] objPres = item.GetCustomAttributes(typeof(DescriptionAttribute), true);//获取当前属性的自定义特性列表
                if (objPres.Length > 0)
                {
                    for (int i = 0; i < objPres.Length; i++)
                    {
                        row.CreateCell(rowNum).SetCellValue(((DescriptionAttribute)objPres[i]).Description);//创建行,将当前自定义特性写入
                        rowNum++;//行索引加1,下次往后一格创建行
                    }
                }
            }
 
 
            int j = sheet.LastRowNum + 1, columnNum = 0;
            foreach (var item in data)
            {
                columnNum = 0;
                row = sheet.CreateRow(j++);
 
                var itemProps = item.GetType().GetProperties();  //获取当前对象的属性列表
                foreach (var itemPropSub in itemProps)
                {
                    //获取当前对象特性中的自定义特性[Description("自定义特性")]
                    var objs = itemPropSub.GetCustomAttributes(typeof(DescriptionAttribute), true);
                    if (objs.Length > 0)
                    {
                        //将当前对象的特性值,插入当前行的第n列单元格
                        row.CreateCell(columnNum).SetCellValue(itemPropSub.GetValue(item, null) == null ? "" : itemPropSub.GetValue(item, null).ToString());
                        columnNum++;
                    }
                }
            }
 
            //文件流写入
            using (MemoryStream ms = new MemoryStream())
            {
                workBook.Write(ms);
                using (FileStream fs = new FileStream(excelName, FileMode.Create, FileAccess.Write))
                {
                    ms.WriteTo(fs);
                }
                ms.Flush();
                ms.Position = 0;
                workBook.Close();
            }
        }
    }

StudentModel

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//实体类
public class StudentModel
    {
        [Description("学号")]
        public string ID { get; set; }
        [Description("姓名")]
        public string Name { get; set; }
        [Description("年龄")]
        public string Age { get; set; }
        [Description("性别")]
        public string Six { get; set; }
        [Description("地址")]
        public string Address { get; set; }
        [Description("电话")]
        public string Tel { get; set; }
    }

调用:

?
1
2
3
4
List<StudentModel> stdList = new List<StudentModel>();
stdList.Add(new StudentModel() { ID = "001", Name = "Peter", Age = "26", Six = "男", Address = "东京", Tel = "123456789" });
stdList.Add(new StudentModel() { ID = "002", Name = "Jerry", Age = "36", Six = "男", Address = "首尔", Tel = "987654321" });
ExcelHelper<StudentModel>.SaveExcelFile(Application.StartupPath + "\\StudentInfo.xls", "Student", stdList);

结果:

C#使用NPOI导出Excel类封装

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_34699535/article/details/106225726

延伸 · 阅读

精彩推荐
  • C#浅谈static a[n*m]={0};中static的作用

    浅谈static a[n*m]={0};中static的作用

    下面小编就为大家带来一篇浅谈static a[n*m]={0};中static的作用。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    C#教程网4302021-12-29
  • C#C#泛型设计需要注意的一个小陷阱

    C#泛型设计需要注意的一个小陷阱

    这篇文章主要给大家介绍了关于C#泛型设计需要注意的一个小陷阱,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学...

    詹姆斯.辛11262022-07-11
  • C#Unity shader实现移动端模拟深度水效果

    Unity shader实现移动端模拟深度水效果

    这篇文章主要为大家详细介绍了Unity shader实现移动端模拟深度水效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一...

    OwenTA5522022-09-06
  • C#C#表达式目录树示例详解

    C#表达式目录树示例详解

    这篇文章主要给大家介绍了关于C#表达式目录树的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    一只独行的猿10922022-10-13
  • C#C#中的TemplateMethod模式问题分析

    C#中的TemplateMethod模式问题分析

    这篇文章主要介绍了C#中的TemplateMethod模式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考...

    伤之哀霜10252022-09-08
  • C#Unity3D 计时器的实现代码(三种写法总结)

    Unity3D 计时器的实现代码(三种写法总结)

    这篇文章主要介绍了Unity3D 计时器的实现代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    加油IT11642022-11-11
  • C#C#设计模式之Visitor访问者模式解决长隆欢乐世界问题实例

    C#设计模式之Visitor访问者模式解决长隆欢乐世界问题实例

    这篇文章主要介绍了C#设计模式之Visitor访问者模式解决长隆欢乐世界问题,简单描述了访问者模式的定义并结合具体实例形式分析了C#使用访问者模式解决长...

    GhostRider9052022-01-21
  • C#浅谈C#.NET、JavaScript和JSON

    浅谈C#.NET、JavaScript和JSON

    本文介绍了C#.NET、JavaScript和JSON的相关知识,具有很好的参考价值,下面跟着小编一起来看下吧...

    失落の熊熊10292021-12-22