Excel连接字符串在.NET中的应用

简介:
+关注继续查看

介绍几种在.NET中直接连接Excel作为数据源的几种方法以及连接字符串的说明。

Microsoft Jet OLE DB 4.0

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\MyExcel.xls;Extended Properties="Excel 8.0;HDR=Yes;IMEX=1";

  64位机器可以看这里http://www.connectionstrings.com/Articles/Show/using-jet-in-64-bit-environments

  如果上面的连接字符串不奏效,可以尝试下面的格式。有些早期版本的2003格式的Excel文件需要在连接字符串中添加OLEDB前缀作为Provider标识。

OLEDB;Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\MyExcel.xls;Extended Properties="Excel 8.0;HDR=Yes;IMEX=1";

  连接字符串中的双引号是必须的,请注意在代码中进行转义。

  C#,C++中使用\"对双引号进行转义。

  VB6,VBScript中使用""对双引号进行转义。

  XML(或web.config)中使用"对双引号进行转义。

  "HDR=Yes;"用于指示将Excel表格中的第一行作为标题,此时在查询语句中可以将标题作为数据表的字段名使用。"HDR=No;"则表示将Excel表格中的所有行都作为数据内容而不包含标题,此时在查询语句中需要使用F1,F2等作为字段名。如第一列为F1,第二列为F2等,以此类推。

  "IMEX=1;"用于指示始终将Excel单元格中的内容作为text类型的数据。该选项会对Excel文件内容的回写产生影响。

  SQL语法:"Select [Column Name One]", [Column Name Two] From [Sheet One$]"。注意Excel wooksheet的名字必须以"$"结尾并且包含在方括号中。列名如有需要也应当包含在方括号中(如列名中包含有空格其它特殊字符等)。

  如何通过程序获取指定Excel文件中各个Sheet的名称?

using (OleDbConnection connection = new OleDbConnection(connectionString))
{
    DataTable dt 
= connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { nullnullnull"Table" });
    
string sqlStr = "Select * From " + dt.Rows[0]["TABLE_NAME"].ToString();
}

  除了表名和列名的写法有所不同外,SQL语句的使用方法和在SQL Server中基本相同。在.NET中数据访问层仍然可以使用OleDbHelper类,使用方法与普通的数据库一样。

  另外,如果指定的Excel文件需要密码才能打开,你需要在连接字符串中提供连接密码,否则打开Excel文件会失败。具体的内容可以看这里,

http://www.connectionstrings.com/Articles/Show/how-to-open-password-protected-excel-workbook

 

ACE OLEDB 12.0

Provider=Microsoft.ACE.OLEDB.12.0;Data Source=c:\myFolder\myOldExcelFile.xls;Extended Properties="Excel 12.0;HDR=YES";

  使用ACE 12.0可以连接早期版本(97-2003)的Excel文件,对于2003以后版本的Excel也通用,但前提是Office组件中安装了对应的ACE,否则无法使用。可以去下面的地址下载ACE组件。

http://www.microsoft.com/download/en/details.aspx?id=13255

  该连接字符串同样适用于Xlsb和Xlsm格式的Excel文件。

 

Microsoft Excel ODBC Driver

Driver={Microsoft Excel Driver (*.xls)};DriverId=790;Dbq=C:\MyExcel.xls;DefaultDir=c:\mypath;

  使用ReadOnly=0表示连接是只读的,所有对数据源的更新操作将不可回写。

Driver={Microsoft Excel Driver (*.xls)};Dbq=C:\MyExcel.xls;ReadOnly=0;

 

.NET xlReader for Microsoft Excel

Data Source =c:\myExcelFile.xlsx;HDR=yes;Format=xlsx;

  注意上面的连接字符串中使用了HDR=yes参数,表示将Excel数据表的首行作为标题。

 


本文转自Jaxu博客园博客,原文链接:http://www.cnblogs.com/jaxu/archive/2011/07/29/2121022.html,如需转载请自行联系原作者


相关文章
|
23天前
|
数据采集 开发框架 JavaScript
基于.NET Core内置浏览器窗体应用程序界面框架
基于.NET Core内置浏览器窗体应用程序界面框架
19 0
|
3月前
|
存储 算法 Java
.NET应用如何防止被反编译
.NET应用如何防止被反编译
|
3月前
|
Kubernetes 关系型数据库 数据库
.netcore应用容器化部署
.netcore应用容器化部署
|
3月前
|
关系型数据库 MySQL 容器
.netcore应用容器化时更改Expose端口无法访问
.netcore应用容器化时更改Expose端口无法访问
|
3月前
|
关系型数据库 MySQL 开发工具
在wsl中部署.netcore应用
在wsl中部署.netcore应用
|
3月前
|
Kubernetes 数据库 C++
.netcore应用在WSL中的容器化部署
前面,我们讲解了如何在wsl中安装数据库,.netcore运行时,以及如何发布一个.netcore应用,为了构成一个完整的小系列,本节,我们来学习一下,如何将.netcore应用在WSL中容器化。
|
5月前
|
JSON JavaScript 前端开发
.NET 创建无边框的跨平台应用
.NET 创建无边框的跨平台应用
32 0
|
10月前
|
IDE 安全 物联网
快速入门 .NET nanoFramework 开发 ESP32-Pico 应用
本文是一篇适合初学者的 .NET nanoFramework 保姆级入门教程,并提供了基本的入门程序并介绍了微雪的 ESP32-S2-Pico 使用 .NET nanoFramework 开发过程的基础知识。
328 0
快速入门 .NET nanoFramework 开发 ESP32-Pico 应用
|
11月前
|
SQL 监控 前端开发
.Net服务器性能监控,应用耗时统一监控平台
系统用于集群的性能监控,应用耗时监控管理,统一日志管理等多维度的性能监控分析。用于监控Windows服务器监控,支持定义插件扩展、Cpu、内存、磁盘读写、网络、iis等性能直播监控,应用好事监控、数据库性能、慢Sql监控、Api监控。
138 0
.Net服务器性能监控,应用耗时统一监控平台
|
11月前
|
C++ Windows
为.NET应用添加截图功能
本文介绍了 .NET 实现截图功能的思路和过程,如果你仅想了解最后的解决方案,可以直接查看文章末尾。
82 0
为.NET应用添加截图功能
推荐文章
更多