在我的第一次尝试中,与py2exe捆绑在一起的pyQt应用程序拒绝连接到sqlite数据库,尽管它在python版本中工作。
我猜想这是一个没有加载到.exe应用程序中的库的问题。我通过将sqlite DLL的完整路径包含到setup.py
文件中,然后将此DLL复制到可执行文件夹来解决了这个问题。
现在我想将此DLL包含到.exe文件中,以便将此DLL“隐藏”给我的用户。 您是否知道如何做到这一点?
我当前的setup.py:
from distutils.core import setup
import py2exe
setup(
windows=[{
"script": 'myscript.py'
}],
options={
'py2exe': {
"dll_excludes": [
"MSVCP90.dll",
"MSWSOCK.dll",
"mswsock.dll",
"powrprof.dll",
],
'includes': [
'sip',
'PyQt4.QtNetwork',
],
'bundle_files': 1,
}
},
data_files = [
'config.ini',
'template.htm',
# This is the File that I wish to be "hidden"
('sqldrivers', ('C:\Python27\Lib\site-packages\PyQt4\plugins\sqldrivers\qsqlite4.dll',)),
zipfile=None,
)
答案 0 :(得分:0)
我遇到了同样的问题,你已经解决了这个问题。问题的第一部分是您确定的,将文件放入EXE。我不能说你的py2exe解决方案的正确性,因为我正在使用pyinstaller,但这是一般的想法。您需要将qsqlite4.dll放入单个文件应用程序中的sqldrivers目录中。
第二部分是你的主.py需要将路径添加到其运行目录中,该目录现在将包含该sqldrivers文件夹。您需要做的是获取运行主.py的相对路径,并将该目录设置为QT应用程序中的库路径。我对pyinstaller使用标准的resource_path()函数,但使用类似的东西应该适用于py2exe:
def resource_path(relative_path)
if sys.frozen:
base_path = os.path.dirname(sys.executable)
else:
base_path = os.path.dirname(__file__)
return os.path.join(base_path, relative_path)
然后您可以在应用程序的主要功能中使用此代码
app = QApplication(sys.argv)
new_lib_path = app.libraryPaths()
new_lib_path.append(resource_path(''))
app.setLibraryPaths(new_lib_path)
. . .
添加了日志记录,这是我的app.libraryPaths()之前和之后:
08/25/2014 01:33:24 AM CRITICAL: Before[u'C:/dev/WORKSP~1/db/dist']
08/25/2014 01:33:24 AM CRITICAL: After[u'C:/dev/WORKSP~1/db/dist', u'C:\\Users\\jeff\\AppData\\Local\\Temp\\_MEI2042\\']
您可以将'\'替换为'/',但我没有打扰,它仍适用于Windows分隔符。