pyinstaller利用配置文件打包

本文介绍如何使用PyInstaller将Python项目打包成exe文件。包括配置spec文件、使用不同模式(-F和-D)打包程序的方法,以及解决常见问题如遗漏模块和图标设置等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

readModel.spec文件 

# -*- mode: python ; coding: utf-8 -*-


block_cipher = None


a = Analysis(['readModel.py'],  #需要打包文件的文件名字典们可以多个.py
文件
             pathex=['D:\\Company\\project\\untitled',
             'D:\\Company'],         #项目路径
             binaries=[( '/usr/lib/libiodbc.2.dylib', '.' )],       #程序调用外部dll文件(文件路径,存放路径)
             datas=[('image/*.png','data/image'),
			('pdf/*.pdf','data/pdf')],          #存放的资源文件(存放路径,路径,属性)
             hiddenimports=['sklearn.utils._typedefs'],#解析模块时,可能会遗漏的模块
             hookspath=[],
             hooksconfig={},
             runtime_hooks=[],
             excludes=[],   #python有很多库,把不需要的添加到里面去
             win_no_prefer_redirects=False,
             win_private_assemblies=False,
             cipher=block_cipher,
             noarchive=False)
             #.pyz程序包,包含程序运行需要的依赖
pyz = PYZ(a.pure, a.zipped_data,
             cipher=block_cipher)

#生成单个exe程序需要的属性及配置
exe = EXE(pyz,
          a.scripts,
          a.binaries,
          a.zipfiles,
          a.datas,  
          [],
          name='readModel',# 文件夹的名字
          debug=False,
          bootloader_ignore_signals=False,
          strip=False,
          upx=True,  # 打包的时候进行压缩,False表示不压缩
          upx_exclude=[],
          runtime_tmpdir=None,
          console=False,# 是否显示黑窗口,刚开始打包的时候一般都会有问题,建议设为True,解决所有问题后可以设置为False)
          disable_windowed_traceback=False,
          target_arch=None,
          icon = 'huitao.ico'#exe的图标
          codesign_identity=None,
          entitlements_file=None )

生成spec文件:

pyi-makespec [-F/-D] xxx.py

把spec文件打包成exe文件

pyinstaller -D -w xxx.spec 

pyinstaller -F -w --hidden-import sklearn.utils._typedefs readModel.py 

pyinstaller -F -w --icon=my.ico test.py 

解释:

异常:

 AttributeError: 'str' object has no attribute 'items'

使用命令“pip install --upgrade setuptools”更新三方库setuptools

pathex=['D:\\abc\\def\\project_v1.0'], # 项目路径
       binaries=[], # 程序调用外部pyd、dll文件(二进制文件路径)以数组形式传入;例:('D:\\pro\\text.dll', 'pro'),将'pdftotext.dll'pro,与原项目结构一致即可
       datas=[], # 存放的资源文件(图片、文本等静态文件)以数组形成传入;例:('D:\\static\\c.ioc','static'),将'cc.ioc'打包之后放在static目录,与原项目结构一致即可
       hiddenimports=[], # pyinstaller解析模块时可能会遗漏某些模块(not visible to the analysis phase),造成打包后执行程序时出现类似No Module named xxx;这时就需要在hiddenimports中加入遗漏的模块

 -F和-D的区别

-F模式程序启动的时候因为需要解压并拷贝依赖和资源文件到临时运行环境_MEIxxxxxx,所以启动速度是比-D模式程序要慢的,运行结束后会删除临时运行环境的文件夹。在Linux和相关系统中,可能有“no-execution”选项,但是对于-F模式程序是不兼容的。由于_MEIxxxxxx是唯一的,所以可以同时运行多个程序,多个程序时互不干涉的。如果程序崩溃了,或者强行结束了(比如在Windows的任务管理器中杀死了进程),_MEIxxxxxx文件夹是不会被删除的,所以频繁崩溃或者结束进程会导致有多个_MEIxxxxxx文件夹,会非常占用磁盘空间,可以使用--runtime-temdir指定_MEIxxxxxx的存放位置。

-D将程序打包为一个文件夹,文件夹中包含启动程序的exe文件和其他依赖的资源文件和DLL文件等。 -D模式程序的运行:运行程序的时候,其实开始运行的是一个pyinstaller生成的引导加载程序bootloader,bootloader是根据不同的操作系统生成的,运行bootloader时,会创建一个临时的Python环境以便运行Python程序,所以使用exe程序时不用安装Python也能运行这个程序。

### 如何使用 PyInstaller 打包 Python 应用程序 #### 安装 PyInstaller 工具 为了能够利用 PyInstaller 进行打包操作,首先需要确保已经安装了该工具。可以通过 pip 来完成这一过程: ```bash pip install pyinstaller ``` 这一步骤会下载并设置好所有必要的组件来支持后续的打包工作[^1]。 #### 创建简单的 Python 脚本作为例子 假设有一个名为 `app.py` 的简单 Python 程序,其功能是从给定路径读取配置文件的内容并向控制台打印出来。这里假定配置文件位于同一目录下,并命名为 `config.txt`: ```python def read_config(file_path): with open(file_path, 'r') as file: content = file.read() print(content) if __name__ == "__main__": config_file = "config.txt" read_config(config_file) ``` 此代码片段展示了如何打开指定位置的文本文件并将其中的信息输出到终端窗口中[^3]。 #### 处理配置文件的方法 当准备将上述应用转化为独立可执行文件时,重要的是要让最终生成的应用知道去哪里寻找所需的资源——比如这里的配置文件。对于这种情况,有两种常见做法: - **相对路径法**: 如果希望保持源码结构不变,则可以在调用 PyInstaller 时通过 `-p` 参数指明额外的数据文件夹;或者修改脚本内部逻辑使其接受命令行参数传入的具体路径。 - **绝对路径/数据附加法**: 更推荐的做法是在构建过程中直接把所需静态资产嵌入到目标 EXE 中去。为此,需向 PyInstaller 提供一个清单列表(`--add-data`)说明哪些外部资料应该被打包进去以及它们相对于根目录的位置关系。例如,在 Windows 上可以这样做: ```bash pyinstaller --onefile --add-data "config.txt;." app.py ``` 这段指令告诉 PyInstaller 不仅要编译 `app.py`, 同时还要复制 `config.txt` 到输出目录里,并将其放置于顶层文件夹内[^2]。 #### 验证结果 一旦完成了以上步骤之后,进入由 PyInstaller 自动生成的 dist 文件夹查看新创建出来的 .exe 文件即可测试整个流程是否成功。启动这个 exe 文件后应当能看到来自原始 txt 文档里的字符串被正常显示出来了[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值