簡體   English   中英

使用OleDB在Excel95工作簿中獲取工作表名稱

[英]Get sheet names in Excel95 workbook using OleDB

我在使用Jet提供程序和OleDb在Excel95工作簿中獲取工作表名稱時遇到了麻煩。

我有一個包含3張圖紙Sheet1,Sheet2,Sheet3的工作簿。 我正在使用以下代碼提取工作表名稱:

var connectionString =
String.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=\"Excel 8.0;HDR=YES;IMEX=1\"", filePath);

using (var connection = new OleDbConnection(connectionString))
{
    connection.Open();
    var dtXlsSchema = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);        
}

最終,對於Sheet1,返回僅包含一個記錄的數據表。 我猜連接字符串有問題嗎?

按照此頁面 ,在連接字符串中使用Excel 5.0代替Excel 8.0。

有幫助嗎?

編輯:

"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=\"Excel 5.0;HDR=YES;IMEX=1\"", filePath);

EDIT2:

Excel版本:為Excel 95工作簿(Excel的7.0版本)指定Excel 5.0,為Excel 97,Excel 2000或Excel 2002(XP)工作簿(Excel的8.0、9.0和10.0版本)指定Excel 8.0。

OleDb將不會發現有空的工作表。

只要工作表中包含一些數據,就應該得到它們的名稱。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM