ADO.NET直接连接Excel文件

以前我读取Excel文件的内容,经常使用的方式是借助Microsoft.Office.Interop.Excel中的相关组件,直接操作其封装好的Excel对象,其实还有一种更方便的方式,就是使用Ado.net直接连接excel文件,然后就可以直接操作DataTable.

 

 public static DataSet CreateDataSource()
        {
            OpenFileDialog dialog = new OpenFileDialog();
            if (dialog.ShowDialog() != DialogResult.OK)
                return null;
            string filename = dialog.FileName;
            string strConn;
            strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +
            "Data Source=" + filename +
            ";Extended Properties=Excel 8.0;";
            try
            {
                OleDbConnection conn = new OleDbConnection(strConn);
                OleDbDataAdapter myCommand = new OleDbDataAdapter("SELECT * FROM [数据$]", strConn);
                DataSet myDataSet = new DataSet();
                myCommand.Fill(myDataSet);
                return myDataSet;
            }
            catch (Exception ex )
            {
                MessageBox.Show("打开文件时出错:" + ex.Message);
                return null;
            }
          
        }

 

//sql 语句说明 "SELECT * FROM [数据$]",其中 “数据”表示excel中sheet的名称,

如:excel文件中有个叫"Sheet1"的标签页,SQL语句为 SELECT * FROM [Sheet1$]",excel的列会自动转化成DataTable的列,支持中文,会自动判断数据行。

每次只能打开一个sheet。

本人在excel2003与excel2007上测试通过

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值