Ich versuche, Daten aus einer Excel-Datei bei einem Klick auf die Schaltfläche zu erhalten. Meine Verbindungszeichenfolge lautet:
string connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\source\\SiteCore65\\Individual-Data.xls;Extended Properties=Excel 8.0;";
Wenn ich auf die Schaltfläche klicke, erhalte ich folgenden Fehler:
Der Anbieter 'Microsoft.ACE.OLEDB.12.0' ist auf dem lokalen Rechner nicht registriert.
Ich habe keine Ahnung, wie ich das beheben kann. Mein Betriebssystem ist Windows 7.
13 Stimmen
Nur ein nebenbei bemerkter Kommentar: die Verwendung von OLEDB zum Lesen einer Excel-Datei ist alte Technik, sehr langsam und erfordert, wie Sie entdeckt haben, die manuelle Installation von zusätzlichen Paketen 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 in Sql Server importieren, können Sie diese Abfrage von SSMS ausführen:
execute master.dbo.xp_enum_oledb_providers
Es wird Ihnen mitteilen, welche Anbieter es glaubt, dass Sie haben. 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, bekam ich die gleiche 'nicht auf Ihrem lokalen Rechner registriert'-Fehlermeldung wie der OP, für beide Excel 16 und Excel 2007 Dateiformate (OlEDB.16.0 und OlEDB.12.0 jeweils). Es macht Sinn, an diesem Punkt Ihre Verluste zu begrenzen und sich von der Microsoft-Software zu verabschieden.1 Stimmen
Siehe 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
sagt Ihnen, was auf dem Server ist, nicht auf Ihrer lokalen Maschine.6 Stimmen
Hier der, 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" zum Befehl hinzu: "C:\Verzeichnispfad\AccessDatabaseEngine_x64.exe" /passive