• 关于Excel的读取


    Excel 连接字符串

     string xlsConnFormat = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source='{0}';Extended Properties='Excel 8.0;HDR=NO;IMEX=1';";
    

    1、HDR表示要把第一行作为数据还是作为列名,作为数据用HDR=NO,作为列名用HDR=YES;

    2、通过IMEX=1来把混合型作为文本型读取,避免null值。

    注意:把一个 Excel 文件看做一个数据库,一个sheet看做一张表。语法 "SELECT * FROM [sheet1$]",表单要使用"[]"和"$"。

    使用 OLEDB 读取不同版本 Excel 数据的连接字符串设置

    用OLEDB通过设置连接字符串可以像读取sqlserver一样将excel中的数据读取出来,但是excel2003和excel2007/2010的连接字符串是不同的

    /// <summary>    
       /// 把数据从Excel装载到DataTable    
       /// </summary>    
       /// <param name="pathName">带路径的Excel文件名</param>    
       /// <param name="sheetName">工作表名</param>
       /// <param name="tbContainer">将数据存入的DataTable</param>
       /// <returns></returns> 
       public DataTable ExcelToDataTable(string pathName, string sheetName)
       {
           DataTable tbContainer = new DataTable();
           string strConn = string.Empty;
           if (string.IsNullOrEmpty(sheetName))
           { 
             sheetName = "Sheet1";
           } 
           FileInfo file = new FileInfo(pathName);
           if (!file.Exists) 
           { 
             throw new Exception("文件不存在");
           } 
           string extension = file.Extension;
           switch (extension)
           {
             case ".xls":
                  strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + pathName + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";
                  break;
             case ".xlsx":
                  strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + pathName + ";Extended Properties='Excel 12.0;HDR=Yes;IMEX=1;'";
                  break;  
            default: 
                  strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + pathName + ";Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";
                  break; 
           }       
         //链接Excel
         OleDbConnection cnnxls = new OleDbConnection(strConn);
         //读取Excel里面有 表Sheet1
         OleDbDataAdapter oda = new OleDbDataAdapter(string.Format("select * from [{0}$]", sheetName), cnnxls);   
         DataSet ds = new DataSet();  
         //将Excel里面有表内容装载到内存表中!
         oda.Fill(tbContainer); 
         return tbContainer; 
       } 
    

     读取Excel文件时,可能一个文件中会有多个Sheet,因此获取Sheet的名称是非常有用的。

    //根据Excel物理路径获取Excel文件中所有表名  
     public static String[] GetExcelSheetNames(string excelFile)  
     { 
              OleDbConnection objConn = null;  
              System.Data.DataTable dt = null;    
                 try 
                 {  
                     //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + excelFile + ";Extended Properties='Excel 8.0; HDR=NO; IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件  
                        string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + excelFile + ";Extended Properties='Excel 12.0; HDR=NO; IMEX=1'"; //此连接可以操作.xls与.xlsx文件  
                    objConn = new OleDbConnection(strConn);  
                     objConn.Open();  
                     dt = objConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);  
                     if (dt == null)  
                     {  
                         return null;  
                     }  
                     String[] excelSheets = new String[dt.Rows.Count];  
                     int i = 0;  
                     foreach (DataRow row in dt.Rows)  
                     {  
                         excelSheets[i] = row["TABLE_NAME"].ToString();  
                        i++;  
                     }  
                      return excelSheets;  
                 }  
                 catch 
                 {  
                     return null;  
                 }  
                 finally 
                 {  
                     if (objConn != null)  
                     {  
                         objConn.Close();  
                         objConn.Dispose();  
                     }  
                     if (dt != null)  
                     {  
                        dt.Dispose();  
                     }  
                }  
     }  
    
  • 相关阅读:
    Android——点击对话框上按钮不关闭对话框
    超酷的Android 侧滑(双向滑动菜单)效果
    Android快速开发不可或缺的11个工具类(下载)
    Android ——真机调试
    Android程序完全退出的三种方法
    android 添加桌面快捷方式
    最全Android开发常用工具类
    成为Java GC专家(5)—Java性能调优原则
    JVM调优总结 + jstat 分析
    mysql中max_allowed_packet参数的配置方法(避免大数据写入或者更新失败)
  • 原文地址:https://www.cnblogs.com/netalen/p/6852289.html
Copyright © 2020-2023  润新知