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();app

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

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

 

参数HDR的值:
HDR=Yes,这表明第一行是标题,不作为数据使用 ,若是用HDR=NO,则表示第一行不是标题,作为数据来使用。系统默认的是YES字符串

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

IMEX ( IMport EXport mode )设置it

  IMEX 有三种模式:io

  0 is Export modedate

  1 is Import modeselect

  2 is Linked mode (full update capabilities)数据

  我这里特别要说明的就是 IMEX 参数了,由于不一样的模式表明著不一样的读写行为:

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

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

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

意义以下:

0 ---输出模式;
1---输入模式;
2----连接模式(彻底更新能力)

相关文章
相关标签/搜索