晓风残月

专注于.NET技术

常用链接

统计

积分与排名

Biz Link

pattern & architecture

Reading

unstrained

网络资源

我的社区

最新评论

ADO.NET 如何读取 Excel (上)

经常需要在数据库与Execl之间互导数据。net时代,ADO.NET可以使用使用Microsoft.Jet.OleDb访问访问Excel,网上已经有很多类似的资源,最典型也是最简单的可能如下:(asp.net环境)

 // 连接字符串            
        string xlsPath 
= Server.MapPath("~/app_data/somefile.xls"); // 绝对物理路径
        string connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                        
"Extended Properties=Excel 8.0;" + 
                        
"data source=" + xlsPath;
        // 查询语句
        string sql 
= "SELECT * FROM [Sheet1$]";

        DataSet ds 
= new DataSet();
        OleDbDataAdapter da = new OleDbDataAdapter(sql, connStr);
        da.Fill(ds);    // 填充DataSet        
        
        // 在这里对DataSet中的数据进行操作        

        // 输出,绑定数据
        GridView1.DataSource 
= ds.Tables[0]; 
        GridView1.DataBind();

很简单吧?!一切就像操作数据库一样,只是需要注意的是:
1。数据提供程序使用Jet,同时需要指定Extended Properties 关键字设置 Excel 特定的属性,不同版本的Excel对应不同的属性值:
用于 Extended Properties 值的有效 Excel 版本。 
对于 Microsoft Excel 
8.0 (97)、9.0 (2000) 和 10.0 (2002) 工作簿,请使用 Excel 8.0。 

对于 Microsoft Excel 
5.0 和 7.0 (95) 工作簿,请使用 Excel 5.0。 

对于 Microsoft Excel 
4.0 工作簿,请使用 Excel 4.0。 

对于 Microsoft Excel 
3.0 工作簿,请使用 Excel 3.0。 

ref:http://msdn.microsoft.com/library/chs/default.asp?url=/library/CHS/dv_vbcode/html/vbtskcodeexamplereadingexceldataintodataset.asp

2。数据源路径使用物理绝对路径(同Access)

3。如何引用表名?
对 Excel 工作簿中表(或范围)的有效引用。 
若要引用完全使用的工作表的范围,请指定后面跟有美元符号的工作表名称。例如: 

select * from 
[Sheet1$]
若要引用工作表上的特定地址范围,请指定后面跟有美元符号和该范围的工作表名称。例如: 

select * from 
[Sheet1$A1:B10]
若要引用指定的范围,请使用该范围的名称。例如: 

select * from 
[MyNamedRange]

ref:http://msdn.microsoft.com/library/chs/default.asp?url=/library/CHS/dv_vbcode/html/vbtskcodeexamplereadingexceldataintodataset.asp
说明:
可以引用Excel 工作簿中的三种对象:
• 整张工作表:[Sheet1$]  ,Sheet1 就是工作表的名称
• 工作表上的命名单元格区域:[MyNamedRange] (不需要指定工作表,因为整个xls中命名区域只能唯一)
XLS命名方法:选中单元格范围》插入》名称》定义
• 工作表上的未命名单元格区域 :[Sheet1$A1:B10]
(在关系数据库提供的各种对象中(表、视图、存储过程等),Excel 数据源仅提供相当于表的对象,它由指定工作簿中的工作表和定义的命名区域组成。命名区域被视为“表”,而工作表被视为“系统表”)

注意:
•必须使用[](方括号),否将报:
FROM 子句语法错误
•必须跟$(美元符号),否则报:
Microsoft Jet 数据库引擎找不到对象'Sheet2'。请确定对象是否存在,并正确地写出它的名称和路径。
•如果工作表名称不对,或者不存在,将报:
'Sheet2$' 不是一个有效名称。请确认它不包含无效的字符或标点,且名称不太长。
•在 如何在 Visual Basic 或 VBA 中使用 ADO 来处理 Excel 数据   中提到可以使用
~  和 '(波浪线和单引号)代替[],使用ADO。NET测试没有成功,报:
FROM 子句语法错误
•当引用工作表明名([Sheet1$])时,数据提供程序认为数据表从指定工作表上最左上方的非空单元格开始。比如,工作表从第 3 行,C 列开始,第3行,C列之前以及第1、2行全为空,则只会显示从第3行,C列开始的数据;以最后表最大范围内的非空单元结束;
•因此,如需要精确读取范围,应该使用命名区域 [NamedRange],或者指定地址:[Sheet1$A1:C10]

4。如何引用列名?
•根据默认连接字符串中,数据提供程序会将有效区域内的第一行作为列名,如果此行某单元格为空则用F1、F2表示,其中序数,跟单元格的位置一致,从1开始;
•如果希望第一行作为数据显示,而非列名,可以在连接串的 Extended Properties 属性指定:HDR=NO
默认值为:HDR=NO应该为 HDR=YES,即默认将第一行作为列名,竟然一直没有发现这个错误,汗upadted 2007年8月18日)格式如下:

        string connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                        
"Extended Properties=\"Excel 8.0;HDR=NO\";" + 
                        
"data source=" + xlsPath;

注意: Excel 8.0;HDR=NO  需要使用双引号(这里的反斜扛,是C#中的转义)

ref:ms-help://MS.VSCC.v80/MS.MSDN.v80/MS.VisualStudio.v80.chs/WD_ADONET/html/745c5f95-2f02-4674-b378-6d51a7ec2490.htm 中 《连接Excel》节(说明:在我自己的MSDN中,它的例子使用了两个双引号是错的,测试没有通过,原文这样说的:

注意,Extended Properties 所需的双引号必须还要加双引号。



在这种情况下,所有的列名都是以F开头,然后跟索引,从F1开始,F2,F3。。。。。。。

5。为什么有效单元格数据不显示出来?
出现这种情况的可能原因是,默认连接中,数据提供程序根据前面单元格推断后续单元个的数据类型。
可以通过 Extended Properties 中指定 IMEX=1

“IMEX=1;”通知驱动程序始终将“互混”数据列作为文本读取

ref:同4

PS:在baidu这个问题的时候,有网友说,将每个单元都加上引号,这固然是格方案,但是工作量何其大啊,又不零活,庆幸自己找到”治本药方“
 
more ref:
如何在 Visual Basic 或 VBA 中使用 ADO 来处理 Excel 数据
http://dotnet.aspx.cc/ShowDetail.aspx?id=C673E2CD-3F1E-4919-8CE0-D69B894A0599

related:
ADO.NET 如何读取 Excel (下)

posted on 2006-08-15 15:16 晓风残月 阅读(5491) 评论(15)  编辑 收藏 网摘 所属分类: .net frameworkADO.NET

评论

#1楼 2006-08-15 16:01 aspnetx      

???
草稿?
  回复  引用  查看    

#2楼 2006-08-15 16:07 phinecos(洞庭散人)      

???   回复  引用  查看    

#3楼[楼主] 2006-08-17 16:38 晓风残月      

aaa,
竟然没有post上来,
晚上回去,补上。
  回复  引用  查看    

#4楼 2007-07-23 18:18 qiushihua[未注册用户]

strSql = "select * from [" + sheetName +"$]" 这种查询方式只是针对手动建excel的查询,对于其它的则报错,指定的格式不是预期的格式等等。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。   回复  引用    

#5楼 2007-08-17 11:05 菜园子[未注册用户]

当不知道工作表名的情况下,怎么查询?
select * from [?$]
  回复  引用    

#6楼 2007-12-24 15:08 wyf[未注册用户]

如果第一列是数字,怎么也显示Fx,x=1,2...
怎么解决?
  回复  引用    

#7楼 2008-05-19 13:19 岁月静好[未注册用户]

楼主你好,怎样将Excel里的数据读到数组里啊?我是新手,请详细点,谢了!   回复  引用    

#8楼[楼主] 2008-05-19 16:40 晓风残月      

根据文中所述读取到DataTable中,就可以很容易进行其他处理了,
比如你可以遍历 DataTable.Rows 转换成 Array
  回复  引用  查看    

#9楼 2008-05-19 17:26 岁月静好[未注册用户]

代码在c#的Windows应用程序中不能编译通过,Server.MapPathbu正确,我主要是Windows应用程序编程,但我刚接触c#,不怎么懂,我的QQ530189627,可以在线联系!谢了!   回复  引用    

#10楼[楼主] 2008-05-19 20:15 晓风残月      


Server.MapPath 是ASP.NET 代码,
GridView1 也是 ASP.NET 的控件

string xslPath = "C:\my.xsl";



  回复  引用  查看    

#11楼[楼主] 2008-05-19 20:16 晓风残月      

只要用winform相关的信息替换即可   回复  引用  查看    

#12楼 2008-09-26 16:42 yingko[未注册用户]

那如果我导入的数据第三列是是邮箱,而数据库第二个字段是邮箱,结果插入就插入错误了   回复  引用    




发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 477472




相关文章:

相关链接: