zoukankan      html  css  js  c++  java
  • c#读取excel

    c#读取excel的方法有不少,这里重点讲直接将excel文件读取到dataset中。在实践过程中会有不少问题,特意摘抄在此:

    1.基本的代码

    复制代码
     private DataSet importExcelToDataSet(string FilePath)
            {
                
    string strConn;
                strConn 
    = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + FilePath + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1'";
                OleDbConnection conn 
    = new OleDbConnection(strConn);
               
    // OleDbDataAdapter myCommand = new OleDbDataAdapter("SELECT * FROM [出车登记表$A:K]", strConn);
                OleDbDataAdapter myCommand = new OleDbDataAdapter("SELECT * FROM [出车登记表$A:L]  where f3<>''", strConn);
                DataSet myDataSet 
    = new DataSet();
                
    try
                {
                    myCommand.Fill(myDataSet);
                }
                
    catch (Exception ex)
                {
                    MessageBox.Show(
    "error," + ex.Message);
                }
                
    return myDataSet;
            }
    复制代码

    调用的时候传入参数为excel文件的路径,返回值是一个dataset。

    2.代码注意事项

    2.1这一句“ strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + FilePath + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1'";”。

    2.1.1:Extended Properties后面的值,excel的版本:excel2003/07都要指定为8.0

    2.1.2:HDR=No;表示是否将excle中的第一行也作为数据读取到dataset中

    2.1.3:IMEX=1 表示将某列中既有数值又有文本的统一认为是文本处理,此语句可解决某些单元格内容读取到excel中是空白的问题。

    2.2这一句“ OleDbDataAdapter myCommand = new OleDbDataAdapter("SELECT * FROM [出车登记表$A:L]  where f3<>''", strConn);

    2.2.1:SELECT * FROM  谁都知道是干什么的,后面跟上"[]",里面写要读取的工作表的名字,以美元符号结束,如“工作表1$”这样。

    2.2.2:如果要读取指定范围内的列,则在工作表名字以及美元符号后写上起始列编号+冒号+截止列编号,如“[工作表1$C:K]”。此语句可解决读取过程中出现“包含了太多列”的异常。

    2.2.3如果某些单元格内容为空就不读取此行则增加where条件,假设工作表中的A列中某一个单元格内容为空不读取则写“ WHERE f1<>''”,如果是b列则是f2<>''依此类推。此语句可解决读取完成的datast中包含n多无意义的空行。其他情况需要自行发现了。

    -------------------------------------------------------------------------------------转自

    http://www.cnblogs.com/phcis/archive/2010/11/19/1881769.html

  • 相关阅读:
    POJ3258River Hopscotch(二分)
    POJ3273Monthly Expense(二分)
    POJ1002487-3279(map)
    HDU 3123 GCC
    POJ2031Building a Space Station
    POJ3096Surprising Strings(map)
    模板类
    POJ1265Area
    【ZZ】C 语言中的指针和内存泄漏 & 编写高效的C程序与C代码优化
    学习笔记之MySQL
  • 原文地址:https://www.cnblogs.com/PLifeCopyDown/p/2865853.html
Copyright © 2011-2022 走看看