- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
其他更高级的程序员:
如果这看起来像是令人厌倦的 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 连接时,情况正好相反!
我的环境包括:
是的,我下载并成功安装了 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/
尽管 Jet/OLE DB 参数是相对的 well documented我无法理解这两个连接参数之间的区别: 第一个: Jet OLEDB:Transaction Commit Mode (DBPRO
此查询产生错误 No value given for one or more required parameters : using (var conn = new OleDbConnection("
当文件名有句点时,使用 OLEDB 读取 CSV 文件时出现问题。 我在 C# 中有一个代码,它使用 OleDBProvider 读取 CSV 文件。它适用于常规范式的文件名,例如 Budget.cs
自从我使用经典 ASP 和 Microsoft Access 进行一些编程以来,我们使用“Microsoft.Jet.Oledb”驱动程序来 Access 和显示数据已经很多年了。 我被要求做一些使用
我已经编译了来自运行 VS2007 ATL OLEDB Provider wizard 的示例 OleDb 提供程序代码.我在那篇博文中提供了更完整的细节。代码使 Excel 崩溃。 Sub Test
我正在尝试创建与位于 SharePoint 服务器上的 Excel 文件的 OleDb 连接。我正在玩的示例代码抛出 OleDb 异常“无效的互联网地址”: public static void Co
我得到以下异常 'Microsoft.ACE.OLEDB.12.0' provider is not registered on the local machine 虽然我已经安装了 'Microso
我正在使用 ASP 上的 OleDb 读取 excel 文件。网络(C#)。 所有信息都正常返回,我惊讶地发现,即使 Excel 文件中定义的单元格类型也返回到我的代码中。 问题是我有所有单元格“常规
有人有我可以在 Excel 的 CREATE TABLE 语句中使用的数据类型列表吗?我已经搜索过,但无法提出任何建议;至少不是任何官方的。从一个地方,我发现: CHAR(255) MEMO INT
我需要以编程方式检查 Excel 中多个 OLEDB 数据连接到 SQL 表和 View 的刷新日期。它们都以相同的方式配置并使用相同的连接字符串,我在 VBA 中使用以下命令检查它们: Connec
我正在编写一个 Web 应用程序,该应用程序将通过打开与经过身份验证的用户提交的 Excel 文件的 OLEDB 连接来读取数据。谁能告诉我以这种方式打开 Excel 文件的安全风险吗?我知道危险的宏
我们正在使用 ADO 访问 Oracle 10g 第 2 版,Oracle 10g 的 Oledb 提供程序。我们在连接池方面遇到了一些问题。数据库驻留在远程机器上,并且连接池正在发生。但是如果远程机
我管理一个导入 Excel 文档的旧应用程序。它已经运行了很长时间,但大约 6 个月前,它停止了工作。在断断续续地搜索错误几个月后,我终于发现我需要在 Exceldocument 中的工作表名称末尾添
我试图找到一种方法来保护查询字符串中的撇号。我有一个包含撇号的字符串格式的值,当我尝试插入时它抛出一个错误 例如: Insert into ["excelApp.worksheetsList.Elem
我有一个 C# 应用程序,它使用 OleDBConnection 连接到本地计算机上的命名 SQL Express 实例: _connection = new OleDbConnection(_str
目前我正在搜索连接字符串的属性,它可用于以只读模式连接到 Excel 文件。搜索 Google 得到了很多连接字符串的示例,但我似乎无法在 OleDb 连接字符串的“扩展属性”部分找到所有可能性的规范
我有一个 DataFlow 任务,应该提取大约 1800 万条记录,并在对它们执行一些任务后,将它们插入到另一个 OLEDB 目标中。 问题可以在下面的屏幕截图中看到。 我收到的错误如下: Infor
我有一个关于向命令(MySQL 或 OleDB,我目前使用这两者)添加参数以避免 SQL 注入(inject)的问题。 除了开放的注入(inject)漏洞之外,这个硬编码查询工作得绝对正常; var
我有一个使用 MySQL 数据库的 vb.net 程序。现在我将数据库更改为 Microsoft Access 2010。我更改了所有必要的设置,例如连接首选项、命令等。 问题是:我遇到了一个错误 m
我正在尝试找到一种方法来正确格式化从旧的 Visual Fox Pro 数据库加载数据的 SELECT 语句中的日期。我需要这样做,以便我可以将其加载到 CSV 中,然后将其加载到 MySQL 中,它
我是一名优秀的程序员,十分优秀!