zoukankan      html  css  js  c++  java
  • 在Windows Server2008R2中导入Excel不能使用Jet 4.0的解决方法

    一直使用以下代码从Excel中取数据,速度快方便:

    string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" +  strFileName + ";" + "Extended Properties=Excel 8.0;";
    OleDbDataAdapter ExcelDA = new OleDbDataAdapter("SELECT * FROM [" + strSheet + "$]", strConn);

    DataSet dstExcel = new DataSet();
    ExcelDA.Fill(dstExcel, "ExcelInfo");

     但这次发布到windows 2008 R2上后却报错。上网查询后得知IIS7会支持一部分32位DLL,但对于与底层绑定较深的组件却不支持。Jet 4.0显示属于后一种组件。微软已经不支持Jet 4.0的升级,所以目前没有,今后也不会再出现Jet 4.0的64位版本。

    基于此网上大部分的解决方案是将应用程序池的Enable 32 bit选项设为True(如下图所示)。这种方案的确可以解决问题,但有以下隐患:

    1.今后的发展方向肯定是64位,使用这种方式只是临时解决了问题,治标不治本。

    2.在我们系统中还用到了Oracle Client, SAP Connector等仍旧需要64位

    3.MOSS系统中也可能会用到类似的功能,不可以降到32位

    鉴于以上问题,我开始查找替代方案,终于查到也可以使用Microsoft.ACE.OLEDB对Excel进行操作。修改后的脚本如下:

    string strConn = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source="+  strFileName + ";" + "Extended Properties='Excel 12.0;HDR=YES'";
    OleDbDataAdapter ExcelDA = new OleDbDataAdapter("SELECT * FROM [" + strSheet + "$]", strConn);

    DataSet dstExcel = new DataSet();
    ExcelDA.Fill(dstExcel, "ExcelInfo");

    注意'Excel 12.0;HDR=YES'处的单引号不能少。

    还需注意需安装64位的2007 Office System Driver: Data Connectivity Components

    http://www.microsoft.com/download/en/details.aspx?id=13255

  • 相关阅读:
    线性判别分析(Linear Discriminant Analysis, LDA)算法分析
    OpenCV学习(37) 人脸识别(2)
    OpenCV学习(36) 人脸识别(1)
    OpenCV学习(35) OpenCV中的PCA算法
    PCA的数学原理
    OpenCV学习(34) 点到轮廓的距离
    OpenCV学习(33) 轮廓的特征矩Moment
    OpenCV学习(32) 求轮廓的包围盒
    http://www.cnblogs.com/snake-hand/p/3206655.html
    C++11 lambda 表达式解析
  • 原文地址:https://www.cnblogs.com/ymj126/p/3455829.html
Copyright © 2011-2022 走看看