C# EPPlus read导入读取Excel到DataSet时日期DateTime列的处理

复制代码
public static DataSet ReadExcelToDataSet(string filePath, string sheetName)
        {
            DataSet ds = new DataSet();
            DataRow dr;
            object objCellValue;
            string cellValue;
            using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.ReadWrite))
            {

                EPPlus 5.0 以后的版本需要指定 商业证书 或者非商业证书
                //ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
                using (ExcelPackage package = new ExcelPackage())
                {
                    package.Load(fs);
                    foreach (var sheet in package.Workbook.Worksheets)
                    {
                        if (sheet.Name.ToUpper().Trim() == sheetName.ToUpper().Trim())
                        {
                            #region
                            if (sheet.Dimension == null) continue;
                            var columnCount = sheet.Dimension.End.Column;
                            var rowCount = sheet.Dimension.End.Row;
                            if (rowCount > 0)
                            {
                                DataTable dt = new DataTable(sheet.Name);
                                for (int j = 0; j < columnCount; j++)//设置DataTable列名
                                {
                                    objCellValue = sheet.Cells[1, j + 1].Value;
                                    cellValue = objCellValue == null ? "" : objCellValue.ToString();
                                    dt.Columns.Add(cellValue, typeof(string));
                                }
                                for (int i = 2; i <= rowCount; i++)
                                {
                                    dr = dt.NewRow();
                                    for (int j = 1; j <= columnCount; j++)
                                    {
                                        objCellValue = sheet.Cells[i, j].Value;
                                        if (objCellValue != null)
                                        {
                                            if (sheet.Cells[i, j].Style.Numberformat.Format.IndexOf("yyyy") > -1 && sheet.Cells[i, j].Value.GetType().ToString() == "System.Double")//注意这里,是处理日期时间格式的关键代码 
                                                objCellValue = sheet.Cells[i, j].GetValue<DateTime>();
                                        }
                                        cellValue = objCellValue == null ? "" : objCellValue.ToString();
                                        dr[j - 1] = cellValue;
                                    }
                                    dt.Rows.Add(dr);
                                }
                                ds.Tables.Add(dt);
                            }
                            #endregion
                        }
                    }
                }
            }
            return ds;
        }
复制代码

 

posted on   itjeff  阅读(996)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2014-08-25 MVC之ActionResult
2014-08-25 Html辅助方法 之 Form表单标签
2014-08-25 正则表达式30分钟入门教程
2014-08-25 MVC系统过滤器、自定义过滤器
2014-08-25 MVC 数据验证

导航

< 2025年3月 >
23 24 25 26 27 28 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 1 2 3 4 5
点击右上角即可分享
微信分享提示