Für alle, die hier noch betroffen sind.
Ich habe den Fehler erhalten...
OLEDB-Fehler "Der Anbieter 'Microsoft.ACE.OLEDB.12.0' ist auf dem lokalen Rechner nicht registriert."
...wie vom OP, Shailesh Sahu, beschrieben.
Ich habe 64-Bit Windows 7.
Mein Problem liegt in PowerShell-Skripten, verwendet aber eine Verbindungszeichenfolge, ähnlich wie im Beitrag des OP, sodass meine Erkenntnisse hoffentlich auf C#, PowerShell und jede andere Sprache angewendet werden können, die auf den "Microsoft.ACE.OLEDB"-Treiber angewiesen ist.
Ich habe die Anweisungen in diesem MS-Forumsthread befolgt: http://goo.gl/h73RmI
Zuerst habe ich versucht, die 64-Bit-Version zu installieren, dann die 32-Bit-Version von AccessDatabaseEngine.exe von dieser Seite http://www.microsoft.com/en-us/download/details.aspx?id=13255
Aber leider keine Freude.
Dann habe ich den folgenden Code in PowerShell ausgeführt (von SQL Panda's Seite http://goo.gl/A3Hu96)
(New-Object system.data.oledb.oledbenumerator).GetElements() | select SOURCES_NAME, SOURCES_DESCRIPTION
...was mir dieses Ergebnis lieferte (andere Datenquellen habe ich der Kürze halber entfernt)...
SOURCES_NAME SOURCES_DESCRIPTION
------------ -------------------
Microsoft.ACE.OLEDB.15.0 Microsoft Office 15.0 Access Database Engine OLE DB Provider
Wie Sie sehen können, habe ich Microsoft.ACE.OLEDB.15.0 (fünfzehn) und nicht Microsoft.ACE.OLEDB.12.0 (zwölf)
Also habe ich meine Verbindungszeichenfolge auf 15 geändert und es hat funktioniert.
Ein kurzes PowerShell-Schnipsel, um zu zeigen, wie die Version dynamisch codiert werden kann...
$AceVersion = ((New-Object System.Data.OleDb.OleDbEnumerator).GetElements() | Where-Object { $_.SOURCES_NAME -like "Microsoft.ACE.OLEDB*" } | Sort-Object SOURCES_NAME -Descending | Select-Object -First 1 SOURCES_NAME).SOURCES_NAME
$connString = "Provider=$AceVersion;Data Source=`"$filepath`";Extended Properties=`"Excel 12.0 Xml;HDR=NO`";"
angepasst, um die neueste ACE-Version auszuwählen, wenn mehr als eine vorhanden ist
Hoffentlich kann jetzt jeder, der dies liest, überprüfen, welche OLEDB-Version installiert ist, und die entsprechende Versionsnummer verwenden.
13 Stimmen
Nur ein tangentiales Kommentar: Die Verwendung von OLEDB zum Lesen einer Excel-Datei ist eine veraltete Technologie, sehr langsam und wie Sie festgestellt haben, erfordert sie die manuelle Installation zusätzlicher Pakete auf Ihrer Zielmaschine. (Zugegeben, die Frage wurde 2011 gestellt.) Verwenden Sie stattdessen ClosedXml (verfügbar auf NuGet), das sofort einsatzbereit ist.
7 Stimmen
@ShaulBehr Es wäre schön gewesen, aber ClosedXml funktioniert nur für .xlsx-Dateien, nicht für .xls.
7 Stimmen
Wenn Sie Daten in SQL Server importieren, können Sie diese Abfrage von SSMS ausführen: execute master.dbo.xp_enum_oledb_providers Es wird Ihnen sagen, welche Anbieter es Ihrer Meinung nach gibt. Es hat mir gesagt, dass ich sowohl Microsoft.ACE.OLEDB.16.0 als auch Microsoft.ACE.OLEDB.12.0 habe, aber als ich versuchte, Daten zu importieren, erhielt ich die gleiche Fehlermeldung 'nicht auf Ihrem lokalen Computer registriert' wie der OP, für beide Excel 16 und Excel 2007 Dateiformate (oledb.16.0 und oledb.12.0 jeweils). Es ergibt Sinn, an diesem Punkt die Verluste zu akzeptieren und auf die Microsoft-Software zu verzichten.
1 Stimmen
Siehen Sie auch diese Antwort stackoverflow.com/a/14401857/21579 für den Unterschied zwischen Microsoft.Jet.OleDb und Microsoft.Ace.OleDb.
4 Stimmen
@user1040323,
execute master.dbo.xp_enum_oledb_providers
zeigt Ihnen, was auf dem Server ist, nicht auf Ihrem Lokalen Computer.6 Stimmen
Hier derjenige, der funktionieren sollte; - Es ist : Nicht wirklich dokumentiert, aber ich habe einen Weg gefunden, um sowohl die 32-Bit- als auch die 64-Bit-Versionen zu installieren. Fügen Sie einfach das Kommandozeilenargument "/passive" dem Befehl hinzu: "C:\Verzeichnispfad\AccessDatabaseEngine_x64.exe" /passive