【Python】conda虚拟环境下使用pyinstaller打包程序为exe

2023-09-02 23:55:14

一、为什么要用conda虚拟环境

第一点是,pyinstaller打包需要指定程序中使用的库的路径,新手在这一点上很容易出现问题,导致打包后的exe程序执行的时候显示缺少模块。这个问题可能并不能通过简单地指定路径来解决。

第二点就是使用虚拟环境本身的好处了:

  • 可以创建多个不同的Python环境,每个环境可以安装不同版本的Python和不同的包,避免了包之间的冲突和依赖问题。
  • 可以方便地切换和管理不同的Python环境,只需要使用activate和deactivate命令即可。
  • 可以使用conda命令来安装和更新包,不需要使用pip或其他工具。conda还可以安装一些非Python的包,比如gcc,nodejs,cuda等。
  • 可以使用conda-forge等第三方源来获取更多的包,或者使用自定义的源来安装私有的包。
  • 可以使用conda export和conda env create命令来导出和导入环境配置文件,方便在不同的机器上复制相同的环境。

当你进入一个conda虚拟环境后(conda activate xxx),可以使用conda installpip install安装不同的包,因为某些包可能在conda源中没有。

虚拟环境的创建和使用很简单,不是本文的主题,这里不赘述了。

二、pyinstaller用法

PyInstaller 是一个用于将 Python 程序打包成可执行文件的强大工具。它允许你将你的 Python 代码、依赖项和解释器一起打包成一个独立的可执行文件,无需用户安装 Python 或其他依赖项。

2.1 安装 PyInstaller

首先进入项目所在的虚拟环境:

打开Anaconda Powershell Prompt(为什么不直接用Powershell?可以,但不建议,你可以从我本专栏前面的文章找到答案),进入项目所在虚拟环境:

conda activate yt_dlp_env

安装pyinstaller:

conda install pyinstaller

在这里插入图片描述

现在,先看第三节:实际使用示例,然后再回来看第二节。

2.2 基本用法

打包一个 Python 脚本

假设你有一个名为 my_script.py 的 Python 脚本,想将其打包成可执行文件。你可以在命令行中执行以下命令:

pyinstaller my_script.py

这将在当前目录下创建一个 dist 文件夹,其中包含了可执行文件。你可以在 dist 文件夹中找到 my_script(或 my_script.exe,取决于你的操作系统)可执行文件。

2.21 打包一个 Python 项目

如果你的项目包含多个文件,你可以将整个项目目录作为参数传递给 PyInstaller。例如:

pyinstaller my_project_directory

这将在 dist 文件夹中创建一个可执行文件,其中包含了整个项目的所有文件和依赖项。

2.22 打包选项

PyInstaller 支持许多选项,以便你根据需要自定义打包过程。一些常用的选项包括:

  1. 打包选项:

    • -F--onefile生成单个可执行文件
    • -D--onedir:生成一个包含多个文件的目录。
    • -w--windowed:创建一个窗口应用程序,没有控制台窗口。
    • -c--console:创建一个带有控制台窗口的命令行应用程序。
    • -m--name:指定生成的可执行文件的名称。
    • --add-data:添加额外的数据文件到可执行文件中。
  2. 导入选项:

    • -p--paths添加搜索Python模块的路径
    • --hidden-import指定需要手动导入但不在源代码中明确导入的模块
  3. 打包配置选项:

    • --name指定生成的可执行文件的名称
    • --icon指定可执行文件的图标文件
    • --version-file:指定版本信息文件。
    • --upx-dir:指定UPX可执行文件压缩工具的目录。
  4. 调试选项:

    • --debug生成带有调试信息的可执行文件
  5. 优化选项:

    • -O--optimize:使用优化编译Python文件。
    • --noconfirm:禁用优化编译确认提示。
  6. 其他选项:

    • -h--help:显示帮助信息。
    • --clean:清理临时文件。
    • --noconfirm:在覆盖现有输出目录时不进行确认。
    • --noconsole:不显示控制台
    • --python指定python解释器的路径

这只是一些常用的PyInstaller参数,实际上有更多选项可用于更复杂的定制。你可以使用pyinstaller --help命令来查看完整的参数列表和说明。

例如,要生成一个单独的可执行文件并指定其名称,你可以使用以下命令:

pyinstaller -F -n my_app my_script.py

这将生成一个名为 my_app 的单独可执行文件。

2.3 打包依赖项

当使用PyInstaller来打包Python应用程序时,你可以使用一系列重要的选项来设置依赖项和配置生成的可执行文件。以下是一些关键的依赖设置选项:

  1. --hidden-import:通过该选项,你可以指定需要手动导入但不在源代码中明确导入的模块。这对于确保PyInstaller能够识别和包含所有依赖项非常有用。
pyinstaller --hidden-import module_name script.py
  1. --exclude-module:使用该选项可以排除特定模块,不包含在生成的可执行文件中。
pyinstaller --exclude-module module_name script.py
  1. --add-binary:允许将外部二进制文件添加到生成的可执行文件中,这对于包含一些外部库非常有用。
pyinstaller --add-binary "path/to/binary;destination/folder" script.py
  1. --add-data:类似于--add-binary,但用于添加外部数据文件到生成的可执行文件中。
pyinstaller --add-data "path/to/data;destination/folder" script.py
  1. --paths:通过指定额外的模块搜索路径,可以确保PyInstaller能够找到依赖项的位置。
pyinstaller --paths path/to/modules script.py

你也可以手动👇👇

2.31 导出依赖项列表

你可以使用以下命令导出项目的依赖项列表:

pyinstaller --name=my_app --onefile my_script.py --path=/path/to/dependencies

这将创建一个 my_app.spec 文件,其中包含了项目的依赖项列表。

2.32 配置依赖项

编辑 my_app.spec 文件并添加依赖项的路径,如下所示:

# ...
a = Analysis(['my_script.py'],
             pathex=['/path/to/project'],
             binaries=[],
             datas=[],
             ...
             pathex=['/path/to/dependencies'],  # 添加依赖项路径
             ...
             )
# ...

然后,使用以下命令来根据修改后的 my_app.spec 文件打包项目:

pyinstaller my_app.spec

这将使用指定的依赖项路径打包项目。

2.4 自定义打包选项

如果你需要更多的自定义选项,可以编辑 my_app.spec 文件并进行更详细的配置。你可以设置各种选项,包括文件和目录的排除和包含、运行时选项等。详细信息可以在 PyInstaller 的官方文档中找到。

2.5 打包完成后的文件

成功打包后,你将在 dist 目录中找到生成的可执行文件。这个文件可以在没有安装 Python 解释器或其他依赖项的情况下在目标系统上运行。

2.6 注意事项

  • 打包大小:可执行文件的大小可能会比原始 Python 代码大很多,因为它包含了 Python 解释器和依赖项。你可以通过精简依赖项来减小可执行文件的大小。
  • 跨平台问题:PyInstaller 支持在不同的操作系统上打包应用程序,但需要在相应的操作系统上运行 PyInstaller。

三、打包示例

打包如下程序:
在这里插入图片描述


(1)打开Anaconda Powershell Prompt,进入项目所在虚拟环境:

conda activate yt_dlp_env

(2)进入程序所在目录:

cd D:\Python_Study\VideoDownload

(3)打包:

pyinstaller -F --paths=E:\anaconda3\envs\yt_dlp_env\Lib\site-packages --python=E:\anaconda3\envs\yt_dlp_env\python.exe    --icon=wx2.ico --name=Downloader DLP_GUI_Perfect.py

参数说明:

  1. -F:打包成一个可执行文件;
  2. -- path:指定python模块的搜索路径;
  3. --python:指定python解释器路径;
  4. --icon:可执行文件的图标
  5. --name:可执行文件名称

(3)在文件所在目录,打开dist文件夹,即可看到打包好的exe文件;
在这里插入图片描述

在这里插入图片描述

(4)直接打开即可运行,发送给别人也是如此(跨平台应该不行)。

在这里插入图片描述


打包好的exe程序运行时是会打开一个控制台窗口的,有时候是不需要的,比如你是一个GUI的程序。

在使用PyInstaller打包时,你可以使用--noconsole选项来告诉PyInstaller生成一个窗口应用程序而不是控制台应用程序:

pyinstaller -F --paths=E:\anaconda3\envs\yt_dlp_env\Lib\site-packages --python=E:\anaconda3\envs\yt_dlp_env\python.exe  --noconsole  --icon=wx2.ico --name=Downloader DLP_GUI_Perfect.py

但不建议第一次就这样打包,留着控制台,可以查看程序运行报错情况,因为依赖很多的情况下,可能存在依赖没完全指定的情况。


除了依赖问题,还有pyinstaller本身的问题,打包后,可能会改变一些程序的运行逻辑或者某个过程的编码、或者资源访问方式等等。不仅需要注意打包参数的设置,可能还需要修改源代码

因此,需要多次调试才能打包好一个程序(复杂一些的),可以使用--debug参数打包,进行调试。

更多推荐

【音视频】ffplay源码解析-FrameQueue队列

帧队列架构位置结构体源码FrameQueue结构体/*这是一个循环队列,windex是指其中的首元素,rindex是指其中的尾部元素.*/typedefstructFrameQueue{Framequeue[FRAME_QUEUE_SIZE];//FRAME_QUEUE_SIZE最大size,数字太大时会占用大量的内存

【多目标跟踪】 TrackFormer 耗时三天 单句翻译!!!

【多目标跟踪】TrackFormer耗时三天单句翻译!!!TrackFormer:Multi-ObjectTrackingwithTransformersAbstractThechallengingtaskofmulti-objecttracking(MOT)re-quiressimultaneousreasoning

Java面向对象编程

给出数据表score(stu-id,name,math,english,Chinese),下列语句正确的是()A.Selectsum(math),avg(chinese)fromscoreB.Select*,sum(english)fromscoreC.Selectstu-id,sum(math)fromscoreD.

大模型从入门到应用——LangChain:代理(Agents)-[代理执行器(Agent Executor):结合使用Agent和VectorStore]

分类目录:《大模型从入门到应用》总目录代理执行器接受一个代理和工具,并使用代理来决定调用哪些工具以及以何种顺序调用。本文将参数如何结合使用Agent和VectorStore。这种用法是将数据加载到VectorStore中,并希望以Agent的方式与之进行交互。推荐的方法是创建一个RetrievalQA,然后将其作为整体

趣解设计模式之《珍爱生命,远离只狼》

〇、小故事小王最近打算入手一款叫《只狼》的游戏,这款游戏特别的硬核,也就是说,普通的小怪战斗力都特别的强,而作为主角的我们,也很容易被小兵打败。除了游戏中的小兵和Boss很难打败之外,如果在游戏中被杀了,也需要从这章的开头开始打,没办法直接从死亡点附近复活,这个就又为游戏增加了难度。不过,对这款游戏痴迷的玩家依然很多很

MC-4/11/01/400 ELAU 软件允许用户完全访问相机设置

MC-4/11/01/400ELAU软件允许用户完全访问相机设置一个完整的Sentinel模具保护解决方案包括一到四台冲击式摄像机、专用红外LED照明和镜头、Sentinel软件以及所有与模压机连接的必要互连组件。摄像机支架基于磁性,可快速、安全、灵活地部署。此外,一个可选的工业电脑和显示器可在一个移动推车,快速新闻到

移动端H5封装一个 ScrollList 横向滚动列表组件,实现向左滑动

效果:1.封装组件:<template><divclass="scroll-list"><divclass="scroll-list-content":style="{background,color,fontSize:size}"ref="scrollListContent"><divclass="scroll-li

第七章(2):深度学习在自然语言处理NLP中的应用

第七章(2):深度学习在自然语言处理NLP中的应用作者:安静到无声个人主页作者简介:人工智能和硬件设计博士生、CSDN与阿里云开发者博客专家,多项比赛获奖者,发表SCI论文多篇。Thanks♪(・ω・)ノ如果觉得文章不错或能帮助到你学习,可以点赞👍收藏📁评论📒+关注哦!o( ̄▽ ̄)d欢迎大家来到安静到无声的《基于

Python--函数

目录1、定义函数1.1向函数传递信息1.2实参和形参2、传递实参2.1位置实参2.2关键字实参2.3默认值2.4等效的函数调用2.5避免实参错误3、返回值3.1返回简单的值3.2让实参变成可选的3.3返回字典3.4结合使用函数和While循环4、传递列表4.1在函数中修改列表4.2禁止函数修改列表5、传递任意数量的实参

C++学习笔记——类与对象(六个默认成员函数)

1、构造函数在一个类中,编译器会自动生成默认的成员函数,当对象进行初始化时,会默认调用这个函数来初始化。构造函数是一个特殊的成员函数,名字与类名相同,创建类类型对象时由编译器自动调用,以保证每个数据成员都有一个合适的初始值,并且在对象整个生命周期内只调用一次。它的特点是:没有返回值系统自动调用构造函数可以重载名字和类名

简单工厂模式 和 工厂方法 和 抽象工厂的区别

简单工厂模式、工厂方法模式和抽象工厂模式是三种不同的创建型设计模式,它们在对象的创建和封装方面有不同的用途和实现方式。以下是它们之间的主要区别:1.**简单工厂模式(SimpleFactoryPattern)**:-**目的**:简单工厂模式的主要目的是封装对象的创建逻辑,以便客户端代码无需知道具体对象的创建细节。它将

热文推荐