Pyodbc 错误 - Python 到 MS Access

Bee*_*Gee 3 python ms-access odbc pyodbc

我在 Windows 7、Python 2.7 和 Microsoft Access 2013 上运行。

当我尝试运行时:

import pyodbc
conn_string = '''
DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};
UID=admin;
UserCommitSync=Yes;
Threads=3;
SafeTransactions=0;
PageTimeout=5;
MaxScanRows=8;
MaxBufferSize=2048;
FIL=MS Access;
DriverId=25;
DefaultDir=C:\Users\jseinfeld;
DBQ=C:\Users\jseinfeld\Desktop\Databasetest1.accdb;
'''
connection = pyodbc.connect(conn_string)
Run Code Online (Sandbox Code Playgroud)

我收到以下错误消息:

Error: ('HY000', "[HY000] [Microsoft][ODBC Microsoft Access Driver]General error Unable to open registry key Temporary (volatile) Ace DSN for process 0x29dc Thread 0x113c DBC 0x8a3ed48    

Jet'. (63) (SQLDriverConnect); [HY000] [Microsoft][ODBC Microsoft Access Driver]General error Unable to open registry key Temporary (volatile) Ace DSN for process 0x29dc Thread 0x113c DBC 0x8a3ed48

Jet'. (63); [HY000] [Microsoft][ODBC Microsoft Access Driver] Not a valid file name. (-1044); [HY000] [Microsoft][ODBC Microsoft Access Driver]General error Unable to open registry key Temporary (volatile) Ace DSN for process 0x29dc Thread 0x113c DBC 0x8a3ed48 

Jet'. (63); [HY000] [Microsoft][ODBC Microsoft Access Driver]General error Unable to open registry key Temporary (volatile) Ace DSN for process 0x29dc Thread 0x113c DBC 0x8a3ed48

Jet'. (63); [HY000] [Microsoft][ODBC Microsoft Access Driver] Not a valid file name. (-1044)")
Run Code Online (Sandbox Code Playgroud)

我意识到有很多关于 Pyodbc 和 MS Access 的问题。我已经执行了以下操作:

1) 确保我有 64 位 Python 和 64 位 MS Access

2) 授予帐户访问HKEY_LOCAL_MACHINE\SOFTWARE\ODBC注册表项的权限

https://support.microsoft.com/en-us/kb/295297

在python中打开Access数据库时出错

来自 Access ODBC 的“一般错误无法打开临时(易失性)注册表项...”

3)试图确保我有一个有效的连接字符串/sf/ask/452868181/# =

4) 当我尝试运行此代码时,Access 数据库未打开。我已重新启动计算机,但仍然收到此错误。

如果我可以尝试任何其他操作,请告诉我。

Han*_*sUp 5

从一个简单的连接字符串开始,只有DRIVERDBQ属性,没有嵌入的换行符......

conn_string = r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=C:\Users\jseinfeld\Desktop\Databasetest1.accdb;'
Run Code Online (Sandbox Code Playgroud)

一旦最简单的连接字符串开始工作,您就可以根据需要添加和测试其他连接属性。