文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么用C#读取Excel文件

2023-06-18 00:35

关注

这篇文章主要讲解了“怎么用C#读取Excel文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用C#读取Excel文件”吧!

C#读取Excel文件方法一:直接读取(这种直接读取单元格的方法释放很重要)

Excel.Applicationexcel=null;  Excel.Workbookswbs=null;  Excel.Workbookwb=null;  Excel.Worksheetws=null;  Excel.Rangerange1=null;  objectNothing=System.Reflection.Missing.Value;   try  {  excel=newExcel.Application();  excel.UserControl=true;  excel.DisplayAlerts=false;   excel.Application.Workbooks.Open(this.  FilePath,Nothing,Nothing,Nothing,Nothing,  Nothing,Nothing,Nothing,Nothing,Nothing,  Nothing,Nothing,Nothing);   wbs=excel.Workbooks;  wb=wbs[1];  ws=(Excel.Worksheet)wb.Worksheets["Sheet2"];    introwCount=ws.UsedRange.Rows.Count;  intcolCount=ws.UsedRange.Columns.Count;  if(rowCount<=0)  thrownewInvalidFormatException  ("文件中没有数据记录");  if(colCount<4)  thrownewInvalidFormatException  ("字段个数不对");   for(inti=0;i{  this.rowNo=i+1;  object[]row=newobject[4];  for(intj=0;j<4;j++)  {  range1=ws.get_Range(ws.Cells[i+2,j+1],  ws.Cells[i+2,j+1]);  row[j]=range1.Value;   if(row[0]==null)  {  this.isNullRecord++;  break;  }  }   if(this.isNullRecord>0)  continue;   DataRowdataRow=this.readExcel(row);   if(this.isNullRecord==1)  continue;   if(this.verifyData(dataRow)==false)  errFlag++;   this.updateTableCurr(dataRow);  }  }  finally  {  if(excel!=null)  {  if(wbs!=null)  {  if(wb!=null)  {  if(ws!=null)  {  if(range1!=null)  {  System.Runtime.InteropServices.Marshal.  ReleaseComObject(range1);  range1=null;  }  System.Runtime.InteropServices.Marshal.  ReleaseComObject(ws);  ws=null;  }  wb.Close(false,Nothing,Nothing);  System.Runtime.InteropServices.Marshal.  ReleaseComObject(wb);  wb=null;  }  wbs.Close();  System.Runtime.InteropServices.Marshal.  ReleaseComObject(wbs);  wbs=null;  }  excel.Application.Workbooks.Close();  excel.Quit();  System.Runtime.InteropServices.Marshal.  ReleaseComObject(excel);  excel=null;  GC.Collect();  }  }

C#读取Excel文件方法二:通过OleDb连接,把excel文件作为数据源来读取(这里是fill进dataset,也可以返回OleDbDataReader来逐行读,数据较快)

注:这种方法容易把混合型的字段作为null值读取进来,解决办法是改造连接字符串

strConn = "Provider=Microsoft.Jet.  OLEDB.4.0;Data Source=C:\\Erp1912.xls;Extended   Properties='Excel8.0;HDR=Yes;IMEX=1'";

通过Imex=1来把混合型作为文本型读取,避免null值,来实现C#读取Excel文件

privateDataSetimportExcelToDataSet  (stringFilePath)  {  stringstrConn;  strConn="Provider=Microsoft.Jet.  OLEDB.4.0;"+"DataSource="+FilePath+";  ExtendedProperties=Excel8.0;";  OleDbConnectionconn=newOleDbConnection  (strConn);  OleDbDataAdaptermyCommand=newOleDbDataAdapter  ("SELECT*FROM[Sheet1$]",strConn);  DataSetmyDataSet=newDataSet();  try  {  myCommand.Fill(myDataSet);  }  catch(Exceptionex)  {  thrownewInvalidFormatException  ("该Excel文件的工作表的名字不正确,"+ex.Message);  }  returnmyDataSet;  }

感谢各位的阅读,以上就是“怎么用C#读取Excel文件”的内容了,经过本文的学习后,相信大家对怎么用C#读取Excel文件这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯