1

我的 PyQt 应用程序在 Linux 上运行时,在我的 Windows 构建环境中运行时,或者在使用 py2exe 构建它的机器上冻结时运行良好。但是在将冻结的可执行文件及其支持文件移动到另一台机器后,它无法加载数据库驱动程序。

当我拥有 Python2.5 和更早版本的 PyQt 和 py2exe 时,它​​运行良好。但是在升级我的工具链后,我得到了这些错误:

  • dbname.open 返回 false
  • lastError(dbname) 是“未加载驱动程序”

我有一个放置 qsqlite4.dll 的 sqldrivers 文件夹。这对于以前的构建环境是必要的,但移动或重命名该 DLL 不会改变任何行为。我认为这是 Qt 找不到的 DLL,但我无法告诉 Qt 去哪里看。

我目前正在运行这些版本:

  • python-2.6.3
  • PyQt-Py2.6-gpl-4.6-1
  • py2exe-0.6.9.win32-py2.6

Dependency Walker 中的分析给了我这个错误:
LoadLibraryW("\application\sqldrivers\qsqlite4.dll") 返回 NULL。错误:此应用程序无法启动,因为应用程序配置不正确。重新安装应用程序可能会解决此问题 (14001)。
当我向 Dependency Walker 询问有关 Qsqlite4.dll 的详细信息时,它说:
错误:“\application\sqldrivers\QSQLITE4.DLL”的并行配置信息包含错误。

这可以解释为什么 DLL 不会加载,但我仍然不清楚如何修复它。仔细检查显示我调用的大多数 DLL 的错误。我需要为我加载的每个 Qt DLL 包含一个清单吗?

提前致谢。

4

3 回答 3

3

来自未来的亲爱的人们:这是我们迄今为止所发现的......

接受的答案并没有真正说明他们复制了哪些 dll 以及在什么地方。我设法通过在sqldrivers相对于 exe 和 qt dll 所在的目录中复制驱动程序来修复它(我正在使用 PySide,但也应该与 PyQt4 一起使用)。在 setup.py 中:

setup(
    ...,
    data_files = [('sqldrivers', ('C:\Python27\Lib\site-packages\PySide\plugins\sqldrivers\qsqlite4.dll',))],
    ...,
)
于 2012-11-19T11:35:12.650 回答
2

我解决了!

我有一个非常聪明的方法来避免让我的用户安装 vcredist——我将清单和 DLL 复制到两个地方,关于 MS DLL 的所有错误都消失了。那是我开始试图找出这个 SQLite 驱动程序错误的时候。

我没有我想的那么聪明。如果我安装 vcredist,所有“未加载驱动程序”和“未找到 SQL 驱动程序”错误都会消失。精氨酸。

于 2009-10-16T05:14:29.563 回答
0

尝试重新安装 SOLite,或者验证您是否已将 DLL 放在正确的位置,因为我记得 MySQL DLL 必须在 System32 目录中才能开发使用它的东西。

问候。

于 2009-10-16T01:16:03.333 回答