下列步骤允许
module_name导入由PyInstaller创建的可执行文件之外的Python模块(在此命名),并允许该模块导入捆绑到可执行文件中的模块。
- 添加
excludes=['module_name']
到PyInstaller规范中使用的Analysis对象。这样可以防止module_name.py
被捆绑到可执行文件中。 - 添加
sys.path.append(os.path.dirname(sys.executable))
在module_name
应用程序中导入的位置。这允许将其从可执行文件所在的目录中导入,该目录与应用程序要运行的目录不同(由于被解压缩到一个临时文件夹)。 - 在导入外部模块 之前 ,请确保由捆绑模块之一执行由外部模块执行的所有导入。解释器 将无法 解析外部模块的进口对捆绑的模块,但 将 使用已在存在的人
sys.modules
。
作为最后一个例子,请考虑以下内容。
# bundled_module1.pyimport external_module# bundled_module2.py# module content# external_module.pyimport bundled_module2
这将失败,
external_module.py因为找不到导入的模块。但是,以下方法将起作用:
# bundled_module1.pyimport bundled_module2import external_module# bundled_module2.py# module content# external_module.pyimport bundled_module2
如果外部模块应该能够导入的捆绑模块数量有限,那就很好了。对于较大的集合,它可能会变得笨拙。
鉴于文档指出解释器 将 针对捆绑到可执行文件中的模块 来 解析导入,这感觉像是一个可能的错误。不过,并未明确调用与可执行文件外部的模块进行互 *** 作。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)