【一步一步学NPOI】10.导入Excel到DataTable

转自: http://www.cnblogs.com/colder/p/3611906.html


 public static DataTable ExcelToDataTable(string str_FilePath, int int_SheetIndex)
        {
            var extName = Path.GetExtension(str_FilePath);//扩展名
            DataTable dt = new DataTable("MyTable");//创建DataTable

            if (extName == ".xls" || extName == ".xlsx")
            {
                using (var fileStream = new FileStream(str_FilePath, FileMode.Open, FileAccess.Read))
                {
                    HSSFWorkbook workBook = new HSSFWorkbook(fileStream);
                    ISheet sheet = workBook.GetSheetAt(int_SheetIndex);

                    //遍历Excel表头,写入dt
                    foreach (var item in sheet.GetRow(sheet.FirstRowNum).Cells)
                    {
                        dt.Columns.Add(item.ToString(), typeof(string));
                    }

                    IEnumerator enumerator = sheet.GetRowEnumerator();//迭代器
                    while (enumerator.MoveNext())//遍历Excel行
                    {
                        IRow row = enumerator.Current as HSSFRow;//当前行
                        //Excel只有一行
                        if (row.RowNum == sheet.FirstRowNum)
                        {
                            continue;
                        }
                        DataRow dr = dt.NewRow();//datatable行对象
                        foreach (var item in row.Cells)
                        {
                            #region 转换数据类型

                            switch (item.CellType)
                            {
                                case CellType.Boolean:
                                    dr[item.ColumnIndex] = item.BooleanCellValue;
                                    break;
                                case CellType.Formula:
                                    dr[item.ColumnIndex] = item.CellFormula;
                                    break;
                                case CellType.Error:
                                    dr[item.ColumnIndex] = ErrorEval.GetText(item.ErrorCellValue);
                                    break;
                                case CellType.Numeric://数字类型
                                    if (DateUtil.IsCellDateFormatted(item))//日期
                                    {
                                        dr[item.ColumnIndex] = item.DateCellValue.ToString("yyyy/MM/dd");
                                    }
                                    else
                                    {
                                        dr[item.ColumnIndex] = item.NumericCellValue;//普通数字
                                    }
                                    break;
                                case CellType.String:
                                    dr[item.ColumnIndex] = item.StringCellValue;
                                    break;
                                case CellType.Blank:
                                case CellType.Unknown:
                                default:
                                    dr[item.ColumnIndex] = string.Empty;
                                    break;
                            }

                            #endregion

                        }
                        dt.Rows.Add(dr);
                    }
                }
            }
            return dt;
        }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值