在ExcelToSQL这个小程序里面客户要求做到不需要安装office的软件就能读取Excel里面的内容,经过一番折腾找到以下的方法。
http://www.microsoft.com/downloads/en/confirmation.aspx?familyId=7554f536-8c28-4598-9b72-ef94e038c891&displayLang=en
先到微软官方下载ACE OLEDB 12.0,如果连接失效的话直接在官方的select里搜索 “ACE OLEDB 12.0”
然后使用oledbconnection的方法读取数据,链接字串如下
Provider=Microsoft.ACE.OLEDB.12.0;Data Source=c:\myFolder\myExcel2007file.xlsx;Extended Properties="Excel 12.0 Xml;HDR=YES";
获取excel文件第1个sheet的名称的函数
string tableName = null;
//Provider=Microsoft.ACE.OLEDB.12.0;Data Source=c:\myFolder\myExcel2007file.xlsx;Extended Properties="Excel 12.0 Xml;HDR=YES";
using (OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet." +
"OLEDB.4.0;Extended Properties=\"Excel 8.0\";Data Source=" + excelFileName))
{
conn.Open();
DataTable dt = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
tableName = dt.Rows[0][2].ToString().Trim();
}
本文介绍了一种无需安装Office即可读取Excel文件内容的方法。通过下载ACEOLEDB12.0并利用OleDbConnection,实现了对Excel数据的有效访问。文中还提供了一个获取Excel首个工作表名称的示例。
3030

被折叠的 条评论
为什么被折叠?



