C# 读取Excel和DBF文件
//获excel中多个sheet中的数据 /// <summary> /// 读取导入Excel文件内容 /// </summary> /// <param name="fileName">文件路径(上传后)</param> /// <param name="columnString">Excel中的列 名</param> /// <param name="isReadAllExcelSheet">是否读取多个Sheet</param> /// <param name="message">(out)消息提示</param> /// <returns></returns> public DataTable ReadDataFromExcel(string fileName, string columnString, bool isReadAllExcelSheet, out string message) { message = ""; try { string strCon = ""; string fileExt = Path.GetExtension(fileName).ToLower(); if (fileExt == ".xls") { strCon = "Provider = Microsoft.Jet.OLEDB.4.0; Data Source = " + fileName + ";Extended Properties=" + (char)34 + "Excel 8.0;HDR=Yes;IMEX=1;" + (char)34; } else if (fileExt == ".xlsx") { strCon = "Provider = Microsoft.ACE.OLEDB.12.0; Data Source = " + fileName + ";Extended Properties=" + (char)34 + "Excel 12.0;HDR=Yes;IMEX=1;" + (char)34; } else { message = "读取失败,非excel文件格式。"; return null; } OleDbConnection excelConnection = new OleDbConnection(strCon); excelConnection.Open(); #region 获取所有sheet表名称 DataTable excelData = new DataTable(); DataTable getTableNameData = excelConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" }); //获取excel中的第一个sheet中的数据 //ReadEachExcelSheetData(excelConnection, ((String)getTableNameData.Rows[0]["TABLE_NAME"]).ToString(), columnString, ref excelData); //获取excel中有多个sheet中的数据 foreach (DataRow row in getTableNameData.Rows) { excelData = ReadEachExcelSheetData2(excelConnection, ((String)row["TABLE_NAME"]).ToString(), columnString); if (excelData.Rows.Count <= 0) { break; } } getTableNameData = null; #endregion return excelData; } catch (Exception ex) { message = "数据文件或者内容格式有严重错误(" + ex.Message + "),请检查!"; return null; } } public void ReadEachExcelSheetData(OleDbConnection excelConnection, string tableName, string columnString, ref DataTable excelData) { try { tableName = "[" + tableName + "]"; string sql = ""; string queryFieldText = string.Empty; if (string.IsNullOrEmpty(queryFieldText)) { queryFieldText = "*"; } else { foreach (string column in columnString.Split(',')) { queryFieldText += "[" + column + "],"; } queryFieldText = queryFieldText.Trim(','); } sql = @" SELECT {0} FROM {1} "; sql = string.Format(sql, queryFieldText, tableName); DataSet ds = new DataSet(); OleDbDataAdapter myAdp = new OleDbDataAdapter(sql, excelConnection); myAdp.Fill(ds, tableName); if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0) { excelData.Merge(ds.Tables[0]); } } catch (Exception ex) { throw ex; } } //获取excel中第一个sheet中的数据 /// <summary> /// 读取导入Excel文件内容 /// </summary> /// <param name="fileName">文件路径(上传后)</param> /// <param name="columnString">Excel中的列 名</param> /// <param name="isReadAllExcelSheet">是否读取多个Sheet</param> /// <param name="message">(out)消息提示</param> /// <returns></returns> public DataTable ReadDataFromExcel(string fileName, string columnString, bool isReadAllExcelSheet, out string message) { message = ""; try { string strCon = ""; string fileExt = Path.GetExtension(fileName).ToLower(); if (fileExt == ".xls") { strCon = "Provider = Microsoft.Jet.OLEDB.4.0; Data Source = " + fileName + ";Extended Properties=" + (char)34 + "Excel 8.0;HDR=Yes;IMEX=1;" + (char)34; } else if (fileExt == ".xlsx") { strCon = "Provider = Microsoft.ACE.OLEDB.12.0; Data Source = " + fileName + ";Extended Properties=" + (char)34 + "Excel 12.0;HDR=Yes;IMEX=1;" + (char)34; } else { message = "读取失败,非excel文件格式。"; return null; } OleDbConnection excelConnection = new OleDbConnection(strCon); excelConnection.Open(); #region 获取所有sheet表名称 DataTable excelData = new DataTable(); DataTable getTableNameData = excelConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" }); //获取excel中的第一个sheet中的数据 ReadEachExcelSheetData(excelConnection, ((String)getTableNameData.Rows[0]["TABLE_NAME"]).ToString(), columnString, ref excelData); //获取excel中有多个sheet中的数据 //foreach (DataRow row in getTableNameData.Rows) //{ // excelData = ReadEachExcelSheetData2(excelConnection, ((String)row["TABLE_NAME"]).ToString(), columnString); // if (excelData.Rows.Count <= 0) // { // break; // } //} getTableNameData = null; #endregion return excelData; } catch (Exception ex) { message = "数据文件或者内容格式有严重错误(" + ex.Message + "),请检查!"; return null; } } public DataTable ReadEachExcelSheetData2(OleDbConnection excelConnection, string tableName, string columnString) { DataTable excelData = new DataTable(); try { tableName = "[" + tableName + "]"; string sql = ""; string queryFieldText = string.Empty; if (string.IsNullOrEmpty(queryFieldText)) { queryFieldText = "*"; } else { foreach (string column in columnString.Split(',')) { queryFieldText += "[" + column + "],"; } queryFieldText = queryFieldText.Trim(','); } sql = @" SELECT {0} FROM {1} "; sql = string.Format(sql, queryFieldText, tableName); DataSet ds = new DataSet(); OleDbDataAdapter myAdp = new OleDbDataAdapter(sql, excelConnection); myAdp.Fill(ds, tableName); if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0) { excelData.Merge(ds.Tables[0]); } } catch (Exception ex) { throw ex; } return excelData; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix