zoukankan      html  css  js  c++  java
  • OleDb操作不同版本的Excel

    1、操作Excel2007以前(不含2007)的连接字符串

          string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + excelFilePath + ";Extended Properties='Excel 8.0; HDR=Yes;IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件

    2、操作2007以后的Excel的连接字符串   

         string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + excelFilePath + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";    //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)

    说明:
       "HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反。
       "IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。
        如果不去掉"IMEX=1"只能读取Excel内容,无法向Excel中插入数据
        在实际应用中可将Excel看作一个类似Access的文件数据库,通过sql进行增、删、改、查操作。

    示例:在asp.net中读取excel内容显示在gridview控件中

    using System.Data.OleDb;
    using System.Data;
    
     public void ReadExcelFiless()
            {
                //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + Server.MapPath("ExcelFiles/MyExcelFile.xls") + ";Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件
                string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Server.MapPath("ExcelFiles/Mydata2007.xlsx") + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)
    //备注: "HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反。
    //      "IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。 
    
                OleDbConnection conn = new OleDbConnection(strConn);
                OleDbDataAdapter adp = new OleDbDataAdapter("Select * from [Sheet1$]", conn);
                DataSet ds = new DataSet();
                adp.Fill(ds, "Book1");
                this.GridView1.DataSource = ds.Tables["Book1"].DefaultView;
                this.GridView1.DataBind(); 
            }
    

    参考自:http://www.cnblogs.com/kingkongv/archive/2012/08/26/2657436.html
     

     

  • 相关阅读:
    MySQL-keepalived做高可用
    Linux-服务管理
    MySQL-CentOS7上安装Mysql5.7
    MySQL-查看DB文件位置
    游戏编程与游戏种类
    计算机
    python
    python中的构造函数
    IndentationError:expected an indented block错误解决
    python程序的pdb调试方法
  • 原文地址:https://www.cnblogs.com/liancs/p/3879262.html
Copyright © 2011-2022 走看看