注意: Excel ODBC 驅動程式忽略 FirstRowHasNames] 或 [頁首設定

文章翻譯 文章翻譯
文章編號: 288343 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

在此頁中

徵狀

當使用 Microsoft Excel 開放式資料庫連接 (ODBC) 驅動程式連接到 Excel 工作表為 ODBC 資料來源驅動程式假設預設工作表資料的第一列包含資料行標頭 (欄位名稱)。 根據要驅動程式] 文件選擇性 FirstRowHasNames 連線設定可用來變更這個預設行為,藉由使用 0 的 False 及 1 為 True。 但是,在實際上驅動程式忽略這項設定,而且第一列資料永遠視為欄標題。 如果第一列的資料並不包含欄標題或其他項目,有效的結果就是第一列的資料 「 消失"。

發生的原因

FirstRowHasNames 或標頭 (HDR) 參數的值會永遠不會被傳遞至 Excel ODBC 驅動程式。

解決方案

[HDR = 設定已可用且正常運作當您使用 Microsoft Jet OLE DB 提供者和它的 Excel ISAM 驅動程式。 因此,最佳的解決方案是使用 Jet 提供者,而不是 Excel ODBC 驅動程式。

由於 Excel ODBC 驅動程式永遠假設第一列包含欄位名稱,第一列必須永遠包含有效的欄位名稱] 或 [開發人員會願意忽視的空項目。

狀況說明

Microsoft 已確認這是在本文開頭所列之 Microsoft 產品中的有錯誤。

其他相關資訊

重製行為的步驟

  1. 建立新的 Excel 活頁簿,並將它儲存預設名稱,您將在其中建立 Visual Basic 測試專案資料夾中。
  2. 儲存格 A1 中填入隨機資料中的第一個資料行中的幾個儲存格。
  3. 建立新的 Visual Basic 專案,並設定參照至 ActiveX 資料物件 (ADO)。
  4. 輸入並執行下列程式碼:
    Private Sub Form_Load()
      Dim cn As ADODB.Connection
      Dim rs As ADODB.Recordset
      Set cn = New ADODB.Connection
      With cn
        .Provider = "MSDASQL"
        .ConnectionString = "Driver={Microsoft Excel Driver (*.xls)};DBQ=" & App.Path & "\Book1.xls;FirstRowHasNames=0;"
        .Open
      End With
      Set rs = New ADODB.Recordset
      With rs
        Set .ActiveConnection = cn
        .Source = "[Sheet1$]"
        .Open
      End With
      Debug.Print rs.Fields(0).Value
      Debug.Print rs.Fields(0).Name
      rs.Close
      cn.Close
    End Sub
    					
通常您預期看到 Excel 驅動程式將預設欄位名稱 F1 」 指派至欄的資料,並顯示您在儲存格 A1 中輸入第一筆資料錄中資料的開頭。 不過,注意,在您輸入儲存格 A2 列印做為第一筆記錄,儘管的您需要將 FirstRowHasNames為 False 值中的值 [偵錯] 視窗中。 在儲存格 A1 的數值已 「 消失 」 成為欄欄位名稱。

屬性

文章編號: 288343 - 上次校閱: 2003年9月16日 - 版次: 3.2
這篇文章中的資訊適用於:
  • Microsoft Data Access Components 2.1
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.1 Service Pack 1
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.5 Service Pack 1
  • Microsoft Data Access Components 2.5
關鍵字:?
kbmt kbbug kbmdacnosweep kbpending KB288343 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:288343
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com