用ole读取excel时的参数解释

本文介绍了一种使用C#将Excel文件读取到Dataset中的方法,详细讲解了连接字符串配置、数据读取范围及过滤空行等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

### C# 使用 OleDb 读取 CSV 格式的 Excel 文件 在 C# 中,可以利用 `OleDbConnection` 和 `OleDbDataAdapter` 来处理 CSV 文件。以下是实现此功能的一个完整代码示例: ```csharp using System; using System.Data.OleDb; using System.Data; class Program { static void Main() { string filePath = @"C:\path\to\yourfile.csv"; // 替换为实际路径 string connectionString = $"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={System.IO.Path.GetDirectoryName(filePath)};Extended Properties=\"Text;HDR=YES;FMT=Delimited\""; using (OleDbConnection conn = new OleDbConnection(connectionString)) { try { conn.Open(); string query = "SELECT * FROM [" + System.IO.Path.GetFileName(filePath) + "]"; using (OleDbCommand cmd = new OleDbCommand(query, conn)) { using (OleDbDataReader reader = cmd.ExecuteReader()) { while (reader.Read()) // 遍历每一行数据 { Console.WriteLine(reader[0].ToString() + "\t" + reader[1].ToString()); } } } } catch (Exception ex) { Console.WriteLine($"Error: {ex.Message}"); } } } } ``` #### 关键点说明 - **连接字符串配置**: 连接字符串中的 `Provider=Microsoft.Jet.OLEDB.4.0` 是针对旧版 Microsoft Jet 数据库引擎的设置[^1]。如果目标环境支持 ACE Provider,则推荐使用更现代的版本 `Microsoft.ACE.OLEDB.12.0` 或更高版本。 - **扩展属性**: `"Text;HDR=YES;FMT=Delimited"` 表明该文件是一个分隔符文本文件,并且第一行为列头 (`HDR=YES`)。 - **查询语句**: SQL 查询类似于操作数据库表的方式,其中 `[filename.csv]` 被视为虚拟表名。 #### 常见注意事项 当运行上述代码需要注意以下几点: - 如果遇到权限问题,请确认应用程序具有访问指定目录及其子资源的权利。 - 对于 Unicode 编码的支持可能需要额外调整 Extended 属性部分的内容,例如加入 `IMEX=1` 参数来强制混合模式导入/导出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值