• 读取EXCEL文件数字类型字段为空的问题 dodo


    用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----链接模式(完全更新能力)

  • 相关阅读:
    [图论分块] HDU 4858 项目管理
    pytorch 自定义权重变量初始化
    Linux系统下命令静默安装weblogic12c
    第六章 类文件结构(2)
    第六章 类文件结构(1)
    第三章 垃圾收集器与内存分配策略
    第二章(3)实战: OutOfMemoryError异常
    第二章(2)HotSpot虚拟机对象探秘
    第二章(1) Java内存区域与内存溢出异常
    第一章 走进java
  • 原文地址:https://www.cnblogs.com/zgqys1980/p/2530045.html
Copyright © 2020-2023  润新知