python - Python 和 MS Access VBA 之间 OLEDB/ODBC 的相反工作

标签 python vba ms-access odbc oledb

其他更高级的程序员:

如果这看起来像是令人厌倦的 Python 32 位/64 位 ODBC/OLEDB Windows 问题,请原谅我,但我尝试搜索论坛但无法完全找到我的问题的原因。

基本上,我尝试首先使用 pypyodbc 模块通过 ODBC 连接一个非常简单的 Python 脚本,然后使用 adodbapi 模块通过 OLEDB 连接一个非常简单的 Python 脚本,两者都尝试连接到 MS Access 2010 .accdb 数据库。但是,对于 OLEDB,我始终得到 'Provider not found。它可能没有正确安装' 错误。对于 ODBC,我始终收到 “未找到数据源名称且未指定默认驱动程序”

深入挖掘后,发生了一些非凡的事情。在 Python 中,JET.OLEDB.4.0 适用于 .mdb 文件,但 ACE.OLEDB.12.0 不适用于 .accdb 文件。然而,当我运行 Access VBA ADODB 连接时,情况正好相反!

我的环境包括:

  • Python3.4 -32位
  • pywin32-219(安装后安装)
  • Microsoft Office 2010 64 位
  • Windows 7

是的,我下载并成功安装了 AccessDatabaseEngine_x64.exe。是的,我将 ODBC 数据源指向 %Win%/SysWOW64。是的,我在上述文件夹的 odbcad32.exe 中看到了 mdb 和 accdb 的 Access 驱动程序和数据源。是的,我在 regedit 中看到了 Access (*mdb) 和 Access (*mdb, *accdb) 数据源和 Access 驱动程序的注册表项。是的,我重新启动并关闭了我的机器。

OLEDB
以下是我的连接字符串,它返回'Provider not found error...':

import adodbapi
databasename = 'D:\directorypath\DatabaseName.accdb'  
constr = 'Provider=Microsoft.ACE.OLEDB.12.0;Data Source=%s'  % databasename 
db = adodbapi.connect(constr)

值得注意的是,以下连接字符串可以完美地工作,但当然只适用于 .mdb 文件:

import adodbapi
databasename = 'D:\otherdirectorypath\OtherDatabaseName.mdb' 
constr = 'Provider=Microsoft.JET.OLEDB.4.0;Data Source=%s'  % databasename 
db = adodbapi.connect(constr)


ODBC
以下是我的连接字符串,它返回“未找到数据源名称...”:

import pypyodbc
databasename = 'D:\directorypath\DatabaseName.accdb'
constr = 'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=%s;'  % databasename
db = pypyodbc.connect(constr)

像上面一样,下面的工作很理想,但只适用于 .mdb 文件:

import pypyodbc
databasename = 'D:\otherdirectorypath\OtherDatabaseName.mdb'
constr = 'DRIVER={Microsoft Access Driver (*.mdb)};DBQ=%s;'  % databasename
db = pypyodbc.connect(constr)


Access VBA
有趣的是,完全相反的情况发生在 Access VBA 模块(当然还有 ActiveX 数据对象库引用)中,驱动程序和提供程序都使用相同的连接字符串。

代码完美适用于 .mdb 和 .accdb 文件:

Dim constr As String
Dim CN As ADODB.Connection
Dim RS As ADODB.Recordset

constr = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\databasedirectory\DatabaseName.accdb;Persist Security Info=False"

' OR constr = "DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=D:\databasedirectory\DatabaseName.accdb;Persist Security Info=False"

Set CN = New ADODB.Connection
CN.Open (constr)

代码返回错误 - “找不到提供程序”“无法加载指定的驱动程序”:

Dim constr As String
Dim CN As ADODB.Connection
Dim RS As ADODB.Recordset

constr = "Provider=Microsoft.JET.OLEDB.4.0;Data Source=D:\otherdatabasedirectory\OtherDatabaseName.mdb;Persist Security Info=False"

' OR constr = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=D:\otherdatabasedirectory\OtherDatabaseName.mdb;Persist Security Info=False"

Set CN = New ADODB.Connection
CN.Open (constr)


ACE.OLEDB.12.0 对比 ACE.OLEDB.14.0
最后,仍然在 Access VBA 中,只有我认为对应于 MS Access 2007 的 Provider: Microsoft.ACE.OLEDB.12.0 有效。但是, Provider: Microsoft.ACE.OLEDB.14.0 不适用于我安装的 MS Access 2010。这有什么原因吗?

结论
我知道 ActiveX 库是一种不同于 Python 模块库的技术,Microsoft 不允许同时使用 x32 位和 x64 位组件,但为什么我不能得到我想要的结果。我想到了 AccessDatabaseEngine_x64.exe/passive,但我听到奇怪的 Office 结果走这条路。我需要为 64 位安装 Python3.4 吗?请帮助或建议!谢谢。

最佳答案

简答:

是的,如果您安装了 64 位 Office 并且想要从 Python 操作 Access 数据库,那么您应该运行 64 位版本的 Python,以尽量减少麻烦。

更长的答案:

较旧的“Jet”引擎/驱动程序和较新的 Access 数据库引擎(又名“ACE”)引擎/驱动程序是完全独立的实体。

较老的“Jet”司机...

 ODBC: Driver={Microsoft Access Driver (*.mdb)}
OLEDB: Provider=Microsoft.Jet.OLEDB.4.0  

...作为 Windows 操作系统的组成部分安装,但它们仅适用于 32 位应用程序。

您安装了 64 位 Office,因此您拥有更新的“ACE”驱动程序的 64 位版本......

 ODBC: Driver={Microsoft Access Driver (*.mdb, *.accdb)}
OLEDB: Provider=Microsoft.ACE.OLEDB.12.0  

... 而且它们仅适用于 64 位应用程序。

您当前的 32 位 Python 环境可以使用 Jet 驱动程序但不能使用 ACE 驱动程序

您拥有 64 位版本的 Access,因此您的 VBA 代码在 64 位环境中运行,它可以使用 ACE 驱动程序但不能使用 Jet 驱动程序。

关于python - Python 和 MS Access VBA 之间 OLEDB/ODBC 的相反工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25951912/

相关文章:

python - 我可以只抓取特定 header 之后的内容吗?

python - 如何在 python 中使用文本文件中的列表?

python - 查找列表中的元素

python - 训练人脸识别模型

vba - 从VBA读取注册表子项

sql - 从表中删除所有

javascript - 如何让Excel VBA自动点击IE中的javascript a href链接

Excel函数返回月份之间的差异?

mysql - 两个表,两个表中多个字段要连接,单个输出 : How?

c# - 我们如何在C#中将access数据库(.mdb)导入到sql server 2008中