`

excel文件转为DataTable

 
阅读更多
在人员初始化的时候,通常会用到excel编辑好,导入到数据库中。此处就给出了excel转datatable的工具类,后续写入数据库就省略了

#region excel导入为datatable
        /// <summary>
        /// 将excel中的数据导入到DataTable中
        /// </summary>
        /// <param name="isFirstRowColumn">第一行是否是DataTable的列名</param>
        /// <param name="fileName">文件路径</param>
        /// <param name="sheetName">excel工作薄sheet的名称</param>
        /// <returns>返回的DataTable</returns>
        public static DataTable ExcelToDataTable(bool isFirstRowColumn, string fileName, string sheetName = "")
        {
            if (string.IsNullOrEmpty(fileName))
            {
                throw new ArgumentNullException(fileName);
            }
            var data = new DataTable();
            IWorkbook workbook = null;
            FileStream fs = null;
            try
            {
                fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
                if (fileName.IndexOf(".xlsx", StringComparison.Ordinal) > 0)
                {
                    workbook = new XSSFWorkbook(fs);
                }
                if (fileName.IndexOf(".xls", StringComparison.Ordinal) > 0)
                {
                    workbook = new HSSFWorkbook(fs);
                }

                ISheet sheet = null;
                if (workbook != null)
                {
                    //如果没有找到指定的sheetName对应的sheet,则尝试获取第一个sheet
                    if (sheetName == "")
                    {
                        sheet = workbook.GetSheetAt(0);
                    }
                    else
                    {
                        sheet = workbook.GetSheet(sheetName) ?? workbook.GetSheetAt(0);
                    }
                }
                if (sheet == null) return data;
                var firstRow = sheet.GetRow(0);
                //一行最后一个cell的编号 即总的列数
                int cellCount = firstRow.LastCellNum;
                int startRow;
                if (isFirstRowColumn)
                {
                    for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
                    {
                        var cell = firstRow.GetCell(i);
                        var cellValue = cell.StringCellValue;
                        if (cellValue == null) continue;
                        var column = new DataColumn(cellValue);
                        data.Columns.Add(column);
                    }
                    startRow = sheet.FirstRowNum + 1;
                }
                else
                {
                    startRow = sheet.FirstRowNum;
                }
                //最后一列的标号
                var rowCount = sheet.LastRowNum;
                for (var i = startRow; i <= rowCount; ++i)
                {
                    var row = sheet.GetRow(i);
                    //没有数据的行默认是null
                    if (row == null) continue;
                    var dataRow = data.NewRow();
                    for (int j = row.FirstCellNum; j < cellCount; ++j)
                    {
                        //同理,没有数据的单元格都默认是null
                        if (row.GetCell(j) != null)
                            dataRow[j] = row.GetCell(j).ToString();
                    }
                    data.Rows.Add(dataRow);
                }

                return data;
            }
            catch (IOException ioex)
            {
                throw new IOException(ioex.Message);
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message);
            }
            finally
            {
                if (fs != null)
                {
                    fs.Close();
                }
            }
        }
        #endregion



附件为需要用到的第三方dll
参考:https://www.cnblogs.com/lunawzh/p/7966214.html

附件是NPOi最新的2.3.0.0版本,里面的dll都需要引用
分享到:
评论

相关推荐

    两种方式 一种oledb 一种 excel.application excel 转为 datatable

    下面我们将通过具体的代码示例来讲解如何利用 OLEDB 将 Excel 文件转换为 `DataTable`。 **步骤一:确定 Excel 文件类型** 根据提供的代码片段,首先我们需要确定 Excel 文件是 `.xls` 格式还是 `.xlsx` 格式。这...

    Excel转Datatable.pdf

    根据给定文件内容,此文档主要介绍了如何将Excel文件转换为.NET环境中的DataTable,以及如何利用NPOI库来实现这一功能。NPOI是一个开源的.NET库,用于读写Microsoft Office格式的文件,特别是Excel。在.NET中处理...

    读取excel文档转为xml格式

    在本项目中,可能使用了`HSSFWorkbook`或`XSSFWorkbook`对象打开Excel文件,然后通过`ISheet`和`IRow`接口获取数据,最后通过`ICell`对象读取每个单元格的内容。 4. **DataTable**:在将Excel数据转换为XML之前,...

    excel导入生成insert语句

    - 使用EPPlus或NPOI,打开Excel文件并遍历工作表中的每个单元格,将数据加载到DataSet或DataTable中。 - 数据Set可以视作内存中的关系数据库,它包含一个或多个DataTable,每个DataTable代表一个Excel工作表。 - ...

    Excel上传转成DataSet

    通过以上步骤,Excel文件就被转换为DataSet,其中每个工作表对应一个DataTable。这种方式方便了对Excel数据的进一步处理,如查询、筛选、排序等。在实际开发中,可以根据具体需求进行优化,例如处理错误、验证数据...

    C# 将Excel表格转成图片并保存源码

    首先,我们需要一个能够处理Excel文件的库。在.NET Framework中,Microsoft.Office.Interop.Excel是常见的选择,但这个库依赖于安装了Microsoft Office。另一种选择是使用开源的NPOI库,它不依赖于Office,适用于...

    将XML文件转换为Excel文件

    在描述中提到的“将XML数据转换为DataTable并将DataTable导出为Excel文件”,这是一个分两步的过程。第一步是使用XMLReader或其他类似的XML处理库(如LINQ to XML或XmlDocument)从XML文件中读取数据,并将其填充到...

    matlab开发-将状态流数据保存到Excelsheet中

    例如,`writetable(dataTable, 'output.xlsx')`将把数据表`dataTable`保存到名为'output.xlsx'的Excel文件中。如果需要在特定工作表或特定行、列位置写入数据,可以使用额外的参数来指定。 4. **创建工作表**:如果...

    将excel数据转换成dataset示例

    然后,通过调用`GetOleDbSchemaTable`方法获取Excel文件中的所有表名,这些表名存储在一个DataTable对象`dtSheetName`中。遍历这个表格,查找不含$符号结尾的表名(通常是工作表名称),并将它们添加到`List&lt;string&gt;...

    C#使用NPOI上传excel

    首先需要读取excel文件中的内容转为表格 string path为excel表格文件的在本地的地址 Stream fs为上传文件的流可以根据Request.Files[0].InputStream 获得 public DataTable GetexcelDataSet(string path,

    C#从实体对象集合中导出Excel的代码

    最后,利用HttpResponse将内容输出到客户端,设置正确的编码、文件名和内容类型,以便浏览器自动处理为Excel文件下载。 这种方法避免了使用COM+组件(如Microsoft.Office.Interop.Excel)带来的部署复杂性和版本...

    C#基础类库

    CSV文件导入DataTable和DataTable导出到Csv文件等操作 4.DEncrypt 加密/解密帮助类 DEncrypt C#DEncrypt加密/DEncrypt解密帮助类 ,多种方式,可以设置Key DESEncrypt C#DESEncrypt加密/DESEncrypt解密帮助类 ...

    C#基类库(苏飞版)

    CSV文件导入DataTable和DataTable导出到Csv文件等操作 4.DEncrypt 加密/解密帮助类 DEncrypt C#DEncrypt加密/DEncrypt解密帮助类 ,多种方式,可以设置Key DESEncrypt C#DESEncrypt加密/DESEncrypt解密帮助类 ...

Global site tag (gtag.js) - Google Analytics