• Microsoft.Jet.OLEDB.4.0读取EXCEL数据


    用Microsoft.Jet.OLEDB.4.0读取EXCEL数据的代码是这样的:
         string ConnStr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:/aa.xls;Extended Properties='Excel 8.0;HDR=NO;IMEX=1';";
        OleDbConnection Conn=new OleDbConnection(ConnStr);
       Conn.Open();
       string SQL="select * from [sheet1$]";
       OleDbDataAdapter da=new OleDbDataAdapter(SQL,ConnStr);
       DataSet ds=new DataSet();
       da.Fill(ds);
       DataGrid1.DataSource=ds;
       DataGrid1.DataBind();

    问题就出在连接字符串上面,后面一定要加上Extended Properties='Excel 8.0;HDR=NO;IMEX=1'。

    HDR=YES 有两个值:YES/NO,表示第一行是否字段名,默认是YES,第一行是字段名   
    IMEX=1 解决数字与字符混合时,识别不正常的情况.

    参数HDR的值:
    HDR=Yes,这代表第一行是标题,不做为数据使用 ,如果用HDR=NO,则表示第一行不是标题,做为数据来使用。系统默认的是YES

    参数Excel 8.0
    对于Excel 97以上版本都用Excel 8.0

    IMEX ( IMport EXport mode )设置

      IMEX 有三种模式:

      0 is Export mode

      1 is Import mode

      2 is Linked mode (full update capabilities)

      我这里特别要说明的就是 IMEX 参数了,因为不同的模式代表著不同的读写行为:

      当 IMEX=0 时为“汇出模式”,这个模式开启的 Excel 档案只能用来做“写入”用途。

      当 IMEX=1 时为“汇入模式”,这个模式开启的 Excel 档案只能用来做“读取”用途。

      当 IMEX=2 时为“连結模式”,这个模式开启的 Excel 档案可同时支援“读取”与“写入”用途。

    意义如下:

    0 ---输出模式;
    1---输入模式;
    2----链接模式(完全更新能力)

  • 相关阅读:
    互斥锁
    信号量、互斥体和自旋锁
    【设计模式】template method(模板方法)-- 类行为型模式5.10
    C/C++中的auto关键词
    【设计模式】observer(观察者)-- 对象行为型模式5.7
    UML图
    MapReduce阅读
    shell提取文件后缀名,并判断其是否为特定字符串
    shell编程--遍历目录下的文件
    Linux shell字符串截取与拼接
  • 原文地址:https://www.cnblogs.com/NetBelieve/p/3402398.html
Copyright © 2020-2023  润新知