我已成功编辑了我的spec文件,并将包含我数据的文件夹添加到其中。它构建良好,但它仍然无法访问数据。当我尝试运行已编译的.exe时,我收到此错误:Error loading Python DLL: C:\Users\Sal\AppData\Local\Temp\_MEI60122\python27.dll (error code 126)
编辑1 - 我还没有弄清楚我的spec文件是这样的:
a = Analysis(['Clock_In.py'],
pathex=['C:\\Users\\Sal\\Desktop'],
hiddenimports=[],
hookspath=None,
runtime_hooks=None)
a.datas += [('CO_time.pkl','CO_time.pkl', 'DATA')]
a.datas += [('hours.pkl','hours.pkl', 'DATA')]
a.datas += [('Obj_file.pkl','Obj_file.pkl', 'DATA')]
a.datas += [('weekly_hours_dict.pkl','weekly_hours_dict.pkl', 'DATA')]
pyz = PYZ(a.pure)
exe = EXE(pyz,
a.datas,
a.binaries,
a.scripts,
exclude_binaries=True,
name='Clock_In.exe',
debug=False,
strip=None,
upx=True,
console=True,
icon="C:\Users\Sal\Desktop\Raindropmemory-Legendora-BrokenSword.ico")
coll = COLLECT(exe,
a.binaries,
a.zipfiles,
a.datas,
strip=None,
upx=True,
**name='Clock_In')
编辑2
我在64位操作系统(Windows 8)上使用32位python并且引起我的注意,这可能会导致我的问题,但仍然没有解决方案。
编辑3
所以我刚刚尝试下载64位python并将其放入我的系统路径中。用我的.spec文件运行pyinstaller仍然得到完全相同的错误代码!这里发生了什么!但是,一个奇怪的细节是,spec文件中的icon="C:\Users\Sal\Desktop\Raindropmemory-Legendora-BrokenSword.ico")
语句已成功执行并更新了图标,而之前的情况并非如此。
编辑4
这是我在MEIPASS代码中直接从文档中得到的陈述。
if getattr(sys, 'frozen', False):
# we are running in a |PyInstaller| bundle
basedir = sys._MEIPASS
else:
# we are running in a normal Python environment
basedir = os.path.dirname(__file__)
答案 0 :(得分:9)
创建像这样的独立可执行文件后,我发现了同样的错误:
pyi-makespec.exe -F program.py
## Customize script.spec just created
和
pyinstaller.exe -F script.spec
所以我需要以管理员身份运行可执行文件来解决它。
我不知道原因,因为它不是我的电脑。我先在我的工作中完成了这个过程并且像魅力一样工作但不在那里。可能是某些安全配置或python或wxpython的奇怪安装,但我在这里添加此解决方案是因为我正在寻找没有成功的时间,这是一项简单的任务,可以为您节省一些时间在尝试更复杂的方法之前。
答案 1 :(得分:3)
您将该代码段放在Python脚本的顶部,您将变成可执行文件 - 而不是在规范中,而不是在自己的脚本中。我在这里找到了一个例子:
https://shanetully.com/2013/08/cross-platform-deployment-of-python-applications-with-pyinstaller/
答案 2 :(得分:0)
通过将“... \ AppData \ Local \ Temp \”添加到受信任区域来解决问题。
答案 3 :(得分:0)
要做的一件简单事就是删除以下文件夹中的所有内容: C:\用户\ XXX \应用程序数据\漫游\ pyinstaller。 我清理了这个文件夹后修复了这个问题。 也许还会删除上次由Pyinstaller创建的所有文件。
答案 4 :(得分:0)