数据库连接方式读取不到Excel数据值的解决方法
来源:互联网 发布:java bytebuffer mark 编辑:程序博客网 时间:2024/06/09 01:23
由于工作的需要,最近做了一个读取Excel文件数据的程序,采取ADO连接方式来读取Excel数据。
一、问题描述:
工作很顺利地便完成了,心底里有一点点高兴,对自己来讲,这种东西太小儿科化了(呵呵,有点自夸了,别当真^_^)。可是后面的过程中却遇到了较大的麻烦:凡是在Excel中打开的xls文件,如果单元格错误检查存在问题,那么其中的数据读取出来便是空(null)。具体体现在如果这个列为数值型,如果改为文本存储方式或其它方式,那么这些列的数据便读取不到。
二、问题分析:
经过多次测试发现问题都不能解决,除非修改列存储方式,但是这种工作量实在太大,根本没有可行性。冷静下来思考了一下,我估计是驱动程序的问题,便将连接方式如下,可是却出现“找不到可安装的ISAM错误”,实在是比较郁闷。
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + "Extended Properties='Excel 8.0; '";
三、问题解决:
后来经过搜索与分析,将连接方式改成如下,问题解决了:
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + "Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";
成功原因:
参数说明: Microsoft Jet 提供程序用于连接到 Excel 工作簿。在以下连接字符串中,Extended Properties 关键字设置 Excel 特定的属性。“HDR=Yes;”指示第一行中包含列名,而不是数据,“IMEX=1;”通知驱动程序始终将“互混”数据列作为文本读取。
注意http://msdn2.microsoft.com/zh-cn/library/ms254978.aspx 默认情况下,系统认为 Excel 数据源的第一行包含可用作字段名的列标题。如果不是这种情况,则必须将该设置关闭,否则,第一行数据将会“消失”,而被用作字段名称。这可通过向连接字符串的扩展属性添加可选的 HDR= 设置来完成。默认情况下(无需指定)是 HDR=Yes。如果没有列标题,则需要指定 HDR=No;提供程序将字段命名为 F1、F2 等等。因为扩展属性字符串现在包含了多个值,所以必须用引号单独包起来。
- 数据库连接方式读取不到Excel数据值的解决方法
- OLEDB方式读取Excel丢失数据的原因和解决方法
- OLEDB方式读取Excel丢失数据、字符串截断的原因和解决方法
- C# ado读取Excel 读不到数据
- C#读取Excel表中的数据时,为何有些行的字段内容读取不到
- C#读取Excel表中的数据时,有些字段内容读取不到的解决办法
- OpenXml方式读取Excel数据
- 以XML的方式读取Excel文件数据
- 读取excel 的数据
- C# 读取Excel时读取不到第一行的问题。
- 用ODBC方式读取EXCEL时,读取出来的内容无效(#错误)之类的解决方法。
- C#.net读取Excel表中的数据时,有些字段内容(字符串、数字)读取不到的解决办法
- (C++)viScanf读取不到数据的解决办法
- 服务器读取不到POST的数据
- c# 解决读取Excel混合文本类型,数据读取失败的解决方法
- VC用ODBC方式读取Excel数据
- VC用ODBC方式读取Excel数据
- C# OLEDB方式读取Excel文件数据
- 什么是数据结构
- 如何设置Eclipse工作空间的缺省字符编码
- 宽字符集(unicode)操作函数
- springwebflow简单部署
- 关于内存字节大小的测试,用sizeof();
- 数据库连接方式读取不到Excel数据值的解决方法
- Opengl es 纹理映射
- myeclise6.5安装的Aptana eclipse 插件出错
- amount describe
- Hadoop中的RPC实现——客户端通信组件
- DOCTYPE中HTML和XHTML之间的区别
- SoMoClo OS——伟大中间地带的崛起
- hibernate many to many查询
- installing sharepoint 2010 时,sql server的配置注意事项