Ado.Net读取Excel常见问题总结

时间:2010-03-17 16:57:19  来源:第二电脑网  作者:第二电脑网

  第二电脑网导读: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 = "SE...
  正文:经常需要在数据库与Execl之间互导数据。net时代,ADO.NET可以使用使用Microsoft.Jet.OleDb访问访问Excel,网上已经有很多类似的资源,最典型也是最简单的可能如下:(ASP/ target=_blank class=infotextkey>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列开始的数据;以最后表最大范围内的非空单元结束;

"Ado.Net读取Excel常见问题总结"由第二电脑网原创提供,转载请注明:http://www.002pc.com/master/College/Programming/aspnet/13279.html

 1/4    1 2 3 4 下一页 尾页


关键字:

关于《Ado.Net读取Excel常见问题总结》文章的评论

站内搜索: 高级搜索

热门搜索: Windows style 系统 tr IP QQ CPU 安装 function 注册 if td