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

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

服务器之家 - 编程语言 - C# - C#使用NPOI将excel导入到list的方法

C#使用NPOI将excel导入到list的方法

2023-02-09 15:32ゞ瀟灑亾眚ゞ C#

这篇文章主要为大家详细介绍了C#使用NPOI将excel导入到list的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C#使用NPOI将excel导入到list的具体代码,供大家参考,具体内容如下

这个是确定是实体类接收

?
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/// <summary>
/// 将excel导入到list
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="fs">Stream 文件流</param>
/// <param name="list">转换的Dictionary:例如 ("昵称","nickname")</param>
/// <returns></returns>
public static List<T> ExcelToList<T>(this Stream fs, Dictionary<string, string> list) where T : class, new()
        {
            List<T> ts = new List<T>();
            IWorkbook workbook = null;
            ISheet sheet = null;
            T t = new T();
            List<string> listName = new List<string>();
            try
            {   // 获得此模型的公共属性
                var propertys = t.GetType().GetProperties().ToList();
                workbook = new HSSFWorkbook(fs);
 
                if (workbook != null)
                {
                    sheet = workbook.GetSheetAt(0);//读取第一个sheet,当然也可以循环读取每个sheet
 
                    if (sheet != null)
                    {
                        int rowCount = sheet.LastRowNum;//总行数
                        if (rowCount > 0)
                        {
                            IRow firstRow = sheet.GetRow(0);//第一行
                            int cellCount = firstRow.LastCellNum;//列数
                            //循环列数
                            for (int i = 0; i < cellCount; i++)
                            {
                                //循环需要转换的值
                                foreach (var item in list)
                                {
                                    if (item.Key.Equals(firstRow.GetCell(i).StringCellValue))
                                    {
                                        //替换表头
                                        firstRow.GetCell(i).SetCellValue(item.Value);
                                    }
                                }
                                //获取已经替换的表头
                                var s = firstRow.GetCell(i).StringCellValue;
                                //添加到listname
                                listName.Add(s);
                            }
 
                            for (int i = 1; i <= rowCount; i++)
                            {
                                t = new T();
                                IRow currRow = sheet.GetRow(i);//第i行
 
                                for (int k = 0; k < cellCount; k++)
                                {   //取值
                                    object value = null;
                                    if (currRow.GetCell(k) != null)
                                    {
                                        firstRow.GetCell(0).SetCellType(CellType.String);
                                        currRow.GetCell(k).SetCellType(CellType.String);
                                        value = currRow.GetCell(k).StringCellValue;
                                    }
                                    else
                                    {
                                        continue;
                                    }
 
                                    var Name = string.Empty;
                                    //获取第表头的值
                                    Name = listName[k];
                                    //循环属性
                                    foreach (var pi in propertys)
                                    {
                                        if (pi.Name.Equals(Name))
                                        {
                                            //获取属性类型名称
                                            var s = pi.PropertyType.Name;
 
                                            //如果非空,则赋给对象的属性
                                            if (value != DBNull.Value)
                                            {
                                                //判断属性的类型(可以自行添加)
                                                switch (s)
                                                {
                                                    case "Guid":
                                                        pi.SetValue(t, new Guid(value.ToString()), null);
                                                        break;
 
                                                    case "Int32":
                                                        pi.SetValue(t, value.ToString() == "" ? 0 : Convert.ToInt32(value.ToString()), null);
                                                        break;
 
                                                    case "Decimal":
                                                        pi.SetValue(t, value.ToString() == "" ? 0 : Convert.ToDecimal(value.ToString()), null);
                                                        break;
 
                                                    case "DateTime":
                                                        pi.SetValue(t, Convert.ToDateTime(value.ToString()), null);
                                                        break;
 
                                                    case "Double":
                                                        pi.SetValue(t, value.ToString() == "" ? 0 : Convert.ToDouble(value.ToString()), null);
                                                        break;
 
                                                    case "String":
                                                        pi.SetValue(t, value, null);
                                                        break;
 
                                                    default:
                                                        break;
                                                }
                                            }
                                        }
                                    }
                                }
                                //对象添加到泛型集合中
                                ts.Add(t);
                            }
                        }
                    }
                }
                return ts;
            }
            catch (Exception ex)
            {
                if (fs != null)
                {
                    fs.Close();
                }
                return null;
            }
        }

调用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 var list = new Dictionary<string, string>();
            list.Add("ID", "TradeAccountId");
            list.Add("简介", "Intro");
            list.Add("昵称1", "Nickname");
            list.Add("限制人数", "SubscribeLimit");
            list.Add("模式", "SubscribeMode");
            list.Add("收益率", "ProfitRate");
            list.Add("收益", "ProfitLossAmount");
            list.Add("头像", "Img");
            list.Add("平台名称", "Name");
            list.Add("用户昵称", "UserNickname");
 
            FileStream fs = new FileStream(@"C:\Users\Administrator\Desktop\Test\Test\bin\Debug\Export\2021-04-27-14-46-36.xls", FileMode.Open);
            var list3 = fs.ExcelToList<Res_Signal>(list);

实体类

?
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
[Serializable]
public class Res_Signal
    {
        /// <summary>
        /// 交易账号ID
        /// </summary>
        public Guid TradeAccountId { get; set; }
 
        /// <summary>
        /// 交易账号简介
        /// </summary>
        public String Intro { get; set; }
 
        /// <summary>
        /// 交易账号昵称
        /// </summary>
        public String Nickname { get; set; }
 
        /// <summary>
        /// 订阅限制值
        /// </summary>
        public Int32 SubscribeLimit { get; set; }
 
        /// <summary>
        /// 订阅模式 目前都是免费  0免费  1收费
        /// </summary>
        public Int32 SubscribeMode { get; set; }
 
        /// <summary>
        /// 订阅模式名称
        /// </summary>
        public String SubscribeMode_Des { get; set; }
 
        /// <summary>
        /// 平台名称
        /// </summary>
        public String Name { get; set; }
 
        /// <summary>
        /// 头像
        /// </summary>
        public String HeadImg { get; set; }
 
        /// <summary>
        /// 用户昵称
        /// </summary>
        public String UserNickname { get; set; }
 
        /// <summary>
        /// 订阅人数
        /// </summary>
        public Int32 SubscribeCount { get; set; }
 
        /// <summary>
        /// 平台图片
        /// </summary>
        public String Img { get; set; }
 
        /// <summary>
        /// 收益率
        /// </summary>
        public decimal ProfitRate { get; set; }
 
        /// <summary>
        /// 总收益
        /// </summary>
        public decimal ProfitLossAmount { get; set; }
 
}

C#使用NPOI将excel导入到list的方法

C#使用NPOI将excel导入到list的方法

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

原文链接:https://blog.csdn.net/qq_41078088/article/details/116239479

延伸 · 阅读

精彩推荐
  • C#深入理解C#之枚举

    深入理解C#之枚举

    这篇文章主要介绍了C#中可枚举类型,IEnumerable和IEnumerator接口及其泛型实现和迭代器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    逆心6092022-11-25
  • C#WPF弹出带蒙板的消息框

    WPF弹出带蒙板的消息框

    这篇文章主要为大家详细介绍了WPF弹出带蒙板的消息框,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    普通的地球人9212021-12-16
  • C#c# 爬取优酷电影信息(2)

    c# 爬取优酷电影信息(2)

    这篇文章主要介绍了c# 如何爬取优酷电影信息,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下...

    三十三重天5122022-11-02
  • C#C# for循环的经典案例集锦

    C# for循环的经典案例集锦

    本篇文章主要介绍了关于for循环的经典案例,具有很好的参考价值。下面跟着小编一起来看下吧...

    涂涂的世界9982022-01-05
  • C#C#算法之回文数

    C#算法之回文数

    这篇文章介绍了C#算法之回文数,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    痴者工良7352022-12-20
  • C#C# 时间与时间戳互转的方法(13位)

    C# 时间与时间戳互转的方法(13位)

    这篇文章主要介绍了C# 时间与时间戳互转的方法(13位),详细的介绍了常出现的几种时间方式及其时间与时间戳互转的方法,非常具有实用价值,希望此文章...

    代码描绘人生5952022-03-02
  • C#c# 网络编程之tcp

    c# 网络编程之tcp

    这篇文章主要介绍了c# 网络编程之tcp的的相关资料,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下...

    seabluescn8752022-11-01
  • C#详解c#中Array,ArrayList与List<T>的区别、共性与相互转换

    详解c#中Array,ArrayList与List<T>的区别、共性与相互转换

    本文详细讲解了c#中Array,ArrayList与List<T>的区别、共性与相互转换,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需...

    sogeisetsu7402022-12-14