.NET中使用OleDb读取Excel

在.NET中可以用OleDb(Object linking and embeding DataBase)来访问Excel

 1 using System;
 2 using System.Data;
 3 using System.Windows.Forms;
 4 using System.Data.OleDb;
 5 
 6 namespace ExcelDemo
 7 {
 8     public partial class Form1 : Form
 9     {
10         public Form1()
11         {
12             InitializeComponent();
13         }
14 
15         private void button1_Click(object sender, EventArgs e)
16         {
17             //xls为Excel2003-2007版本的Excel文件后缀,而xlsx为2007以上版本的后缀名
18             //var dt = ExcelToDataTable(@"E:\WorkSpace\VS\ExcelDemo\test.xls", "sheet1");
19             var dt = ExcelToDataTable(@"E:\WorkSpace\VS\ExcelDemo\test.xlsx", "sheet1");
20             this.dataGridView1.DataSource=dt;
21         }
22         private DataTable ExcelToDataTable(string strExcelFileName, string strSheetName)
23         {
24             //Jet和Ace都是连接Excel对象的接口引擎,但是二者有区别.
25             //string strConn = "Provider=Microsoft.Jet.OLEDB.8.0;" + "Data Source=" + strExcelFileName + ";" + 
26             //"Extended Properties='Excel 8.0;HDR=Yes;IMEX=1';";
27             string strConn = @"Provider=Microsoft.Ace.OLEDB.12.0;" + "Data Source=" + strExcelFileName + ";" + 
28                 "Extended Properties='Excel 12.0;HDR=Yes;IMEX=1';";
29             string strExcel = string.Format("select * from [{0}$]", strSheetName);
30             //创建OleDb连接,对于特定的数据源类型,传入不同的连接字符串
31             OleDbConnection connection = new OleDbConnection(strConn);
32             connection.Open();
33             OleDbDataAdapter da = new OleDbDataAdapter(strExcel,connection);
34             var ds = new DataSet();
35             da.Fill(ds,strSheetName);
36             return ds.Tables[strSheetName];
37         }
38     }
39 }

 

最开始用的Excel对象接口引擎为Jet,但是在测试时发现对于Excel2013版本的文件,在执行到31行时会报错"外部表不是标准格式".将Excel另存为2003-2007版本时不报错.

原来Jet引擎和Ace引擎是有区别的,具体参考 http://blog.csdn.net/xifeijian/article/details/8333396

 

posted @ 2014-10-08 22:36  fionhan  阅读(397)  评论(0编辑  收藏  举报