zoukankan      html  css  js  c++  java
  • C# 读取EXCEL文件出现数据丢失问题,数据不完整

    将EXCEL数据导出的时候如果同一列数据中既有文字,又有数字!读取时一列中要么文字丢失只剩下数字,要么数字丢失,只剩下文字,这是由第一行的数据类型决定的。出现这种问题是由于数据类型不统一造成的。

    原来的连接字符串为:

    string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Path + "; Extended Properties=Excel 8.0;";

    查阅资料后问题解决:

    string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Path + ";Extended Properties=Excel 8.0;IMEX=1;";

    加的参数解释:

    IMEX=1 解决数字与字符混合时,识别不正常的情况

    HDR=YES 有两个值:YES/NO,表示第一行是否字段名,默认是YES,第一行是字段名

    OLEDB的Excel的IMEX和HDR是什么意思2010-01-23 13:24HDR=NO 即无字段
    HDR=yes 即有字段,一般默认excel表中第1行的列标题为字段名,如姓名、年龄等

    还有问题IMEX有三个值0,1,2,其他两个值分别表示什么

    IMEX 表示是否强制转换为文本

    特别注意

      Extended Properties='Excel 8.0;HDR=yes;IMEX=1'

      A: HDR ( HeaDer Row )设置

      若指定值为Yes,代表 Excel 档中的工作表第一行是栏位名称

      若指定值為 No,代表 Excel 档中的工作表第一行就是資料了,沒有栏位名称

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

  • 相关阅读:
    jq ajax注册检查用户名
    jq ajax页面交互
    Digit Counting UVA – 1225
    Molar mass UVA – 1586
    P1571 眼红的Medusa
    A. Digits Sequence Dividing
    Codeforces Round #535 (Div. 3) a题
    Digit Generator UVA – 1583
    Good Bye 2018 B
    电梯 HDU – 1008
  • 原文地址:https://www.cnblogs.com/lanyue52011/p/3286385.html
Copyright © 2011-2022 走看看