PyQt学习系列09-应用程序打包与部署
PyQt学习系列笔记(Python Qt框架)
第九课:PyQt的应用程序打包与部署
课程目标
- 掌握使用 PyInstaller 将PyQt应用程序打包为独立可执行文件
- 学习处理 资源文件(图标、样式表、图片)和 依赖项
- 实现 跨平台部署(Windows/macOS/Linux)
- 了解 pyqtdeploy 工具的使用(高级打包方案)
- 解决常见问题(如缺少依赖、资源加载失败)
一、打包工具简介
1.1 PyInstaller
- 优点:简单易用,支持单文件/多文件模式,自动识别依赖项。
- 缺点:生成的文件体积较大,调试需查看日志。
1.2 pyqtdeploy
- 优点:专为Qt应用设计,支持多平台打包(Windows/macOS/Linux/iOS/Android)。
- 缺点:配置复杂,需手动处理依赖项。
二、使用PyInstaller打包PyQt应用
2.1 安装PyInstaller
pip install pyinstaller
2.2 基础打包命令
# 单文件模式(推荐)
pyinstaller -F -w your_app.py# 多文件模式(调试推荐)
pyinstaller -w your_app.py
- 参数说明:
-F
:打包为单个可执行文件(onefile
)-w
:隐藏控制台窗口(GUI程序专用)
2.3 处理资源文件
资源文件目录结构
your_project/
├── main.py # 主程序
├── resources/
│ ├── icons/ # 图标文件
│ └── styles.qss # 样式表
├── database/ # 数据库文件
└── images/ # 图片资源
修改资源路径
在代码中动态加载资源:
import sys
import osdef resource_path(relative_path):"""获取资源文件的绝对路径(支持打包后运行)"""if hasattr(sys, '_MEIPASS'):return os.path.join(sys._MEIPASS, relative_path)return os.path.join(os.path.abspath("."), relative_path)# 使用示例
icon_path = resource_path("resources/icons/app_icon.png")
2.4 修改spec文件(高级配置)
-
生成spec文件:
pyinstaller your_app.spec
-
编辑spec文件:
# 添加资源文件路径 from PyInstaller.utils.hooks import collect_data_files datas = collect_data_files('your_project') + [('resources/*', 'resources/')]
-
重新打包:
pyinstaller your_app.spec
2.5 跨平台打包
- Windows:
pyinstaller -F -w your_app.py
- Linux:
pyinstaller -F -w your_app.py
- macOS:
pyinstaller -F -w --osx-bundle-identifier=com.yourcompany.yourapp your_app.py
三、使用pyqtdeploy打包(高级)
3.1 安装pyqtdeploy
pip install pyqtdeploy
3.2 创建配置文件
pyqtdeploy-cli init -t app your_app
配置文件示例(your_app/pyqtdeploy.json
):
{"name": "your_app","version": "1.0","platforms": ["windows", "linux", "macos"],"sources": ["main.py"],"resources": ["resources/*"],"dependencies": ["PyQt5", "sqlite3"]
}
3.3 编译与打包
cd your_app
pyqtdeploy build
输出目录:
dist/
├── windows/
│ └── your_app.exe
├── linux/
│ └── your_app
└── macos/└── your_app.app
四、常见问题与解决方案
4.1 缺少依赖项
- 现象:运行时报错
ImportError: No module named ...
- 解决方法:
- 在spec文件中手动添加依赖:
hiddenimports = ['your_missing_module']
- 使用
--hidden-import
参数:pyinstaller --hidden-import=your_missing_module your_app.py
- 在spec文件中手动添加依赖:
4.2 资源文件无法加载
- 现象:运行时报错
FileNotFoundError: resources/icon.png
- 解决方法:
- 确保使用
resource_path()
函数处理路径。 - 在spec文件中添加资源文件:
datas = [('resources/*', 'resources/')]
- 确保使用
4.3 Linux/macOS运行失败
- 现象:打包后程序无法运行,提示缺少库文件
- 解决方法:
- 安装缺失的依赖:
sudo apt-get install libgl1 libxext6 # Linux 示例
- 使用
ldd
检查依赖:ldd dist/your_app
- 安装缺失的依赖:
五、进阶技巧
5.1 自定义图标
- 准备
.ico
文件(Windows)或.icns
文件(macOS)。 - 在打包命令中添加图标参数:
pyinstaller -F -w --icon=your_icon.ico your_app.py
5.2 自动更新机制
- 使用第三方库(如
pyupdater
)实现自动更新。 - 打包时包含更新脚本:
import pyupdater.client
5.3 分发策略
- Windows:使用
.exe
文件 + 安装包(Inno Setup)。 - Linux:提供
.tar.gz
或.deb
包。 - macOS:提供
.dmg
或.app
包。
六、总结与下一步
本节课重点讲解了:
- PyInstaller 和 pyqtdeploy 的使用方法
- 资源文件 和 依赖项 的处理技巧
- 跨平台部署 的注意事项
- 常见问题 的排查与解决
下节预告:
第十课将讲解PyQt的性能优化与调试技巧,包括内存泄漏检测、日志输出、性能分析工具的使用等!
相关文章:
PyQt学习系列09-应用程序打包与部署
PyQt学习系列笔记(Python Qt框架) 第九课:PyQt的应用程序打包与部署 课程目标 掌握使用 PyInstaller 将PyQt应用程序打包为独立可执行文件学习处理 资源文件(图标、样式表、图片)和 依赖项实现 跨平台部署࿰…...
实现图片自动压缩算法,canvas压缩图片方法
背景: 在使用某些支持webgl的图形库(eg:PIXI.js,fabric.js)场景中,如果加载的纹理超过webgl可处理的最大纹理限制,会导致渲染的纹理缺失,甚至无法显示。 方案 实现图片自动压缩算…...
《数据结构笔记三》:单链表(创建、插入、遍历、删除、释放内存等核心操作)
不带头节点的单链表:(不带表头) #include<stdio.h> #include<stdlib.h> #include<string.h> //定义一个链表节点结构体 typedef struct Node {/* data */int data; //表示节点数据域struct Node *next; //…...
光伏行业如何利用SD-WAN优化分布式网络:替代MPLS、VPN、4G/5G的网络架构升级与云安全方案全解析
光伏行业的网络通信挑战与SD-WAN技术方案对比分析 光伏行业的分布式网络架构、远程站点多、通信环境复杂,以及对实时数据传输的高要求,使得网络架构成为影响行业数字化转型的重要因素。近年来,SD-WAN(软件定义广域网)…...

2025电工杯数学建模A题思路数模AI提示词工程
我发布的智能体链接:数模AI扣子是新一代 AI 大模型智能体开发平台。整合了插件、长短期记忆、工作流、卡片等丰富能力,扣子能帮你低门槛、快速搭建个性化或具备商业价值的智能体,并发布到豆包、飞书等各个平台。https://www.coze.cn/search/n…...

LLM | 论文精读 | NAACL 2025 | Clarify When Necessary:教语言模型何时该“问一句”再答!
🔍 解读 NAACL 2025 重磅论文《Clarify When Necessary》:教语言模型何时该“问一句”再答! 🧩 一、现实问题:大模型“看不懂装懂”有多危险? 我们每天用的 ChatGPT、Claude 等大型语言模型(LL…...

嵌入式鸿蒙openharmony应用开发环境搭建与工程创建实现
各位小伙伴大家好,本周开始分享鸿蒙开发相关的内容,从基础的配置方法到各种功能的实现,探索国产操作系统的奥秘。 第一:观察结果 第二:开源语言 ArkTS是鸿蒙应用开发中使用的TypeScript超集,提供了一套丰富的API来构建应用界面和逻辑。 第三:环境搭建 步骤 1 通过如…...

MDK的编译过程及文件类型全解
本章参考资料:MDK的帮助手册《ARM Development Tools》,点击MDK界面的“help->uVision Help”菜单可打开该文件。 关于ELF文件格式,参考配套资料里的《ELF文件格式》文件。 在本章中讲解了非常多的文件类型,学习时请跟着教程的…...
socc 19 echash论文部分解读
前言:论文还是得吃透才行,不然很多细节有问题 q1 object和data chunck哪一个大 根据论文,一个 data chunk 通常比一个 object 大,因为它是由多个 object 组合而成的 。 论文中提到,cross-coding 会将多个 object 组合…...

Linux Shell编程(八)
目录 Case语句 1--case格式 2--case使用案例:输入不容的数字,给出不同的结果 跳出循环 1--break 案例:执行十次时,跳出当前循环 完整流程 2--continue 案例:跳过2,4 输出 完整流程 Case语句 1--case格式 c…...

AI筑基,新质跃升|英码科技亮相华为广东新质生产力创新峰会,发布大模型一体机新品,助力产业智能化转型
5月15日,以“AI筑基,新质跃升”为主题的华为中国行2025广东新质生产力创新峰会在惠州圆满召开。本次峰会聚焦人工智能、算力基础设施等新ICT技术如何驱动“新质生产力”,共探广东高质量发展新路径。英码科技受邀出席本次峰会,并携…...

手机打电话时由对方DTMF响应切换多级IVR语音菜单(话术脚本与实战)
手机打电话时由对方DTMF响应切换多级IVR语音菜单 (话术脚本与实战) --本地AI电话机器人 上一篇:手机打电话时由对方DTMF响应切换多级IVR语音应答(二) 下一篇:手机打电话时由对方DTMF响应切换多级IVR语音…...

面试题——JDBC|Maven|Spring的IOC思想|DI思想|SpringMVC
目录 一、JDBC 1、jdbc连接数据库的基本步骤(掌握**) 2、Statement和PreparedStatement的区别 (掌握***) 二、Maven 1、maven的作用 2、maven 如何排除依赖 3、maven scope作用域有哪些? 三、Spring的IOC思想 …...

DETR3D- 3D Object Detection from Multi-view Images via 3D-to-2D Queries
MIT CORL 2021 纯视觉BEV方案transformer网络3D检测 paper:[2110.06922] DETR3D: 3D Object Detection from Multi-view Images via 3D-to-2D Queries code:GitHub - WangYueFt/detr3d DNN提图像特征,FPN提多尺度特征 pts_bbox_head Detr3…...

SpringBoot3整合WebSocket
一、WebSocket简介 WebSocket协议是基于TCP的一种新的网络协议。它实现了浏览器与服务器全双工(full-duplex)通信,允许服务器主动向客户端推送数据。 与传统的 HTTP 请求-响应模式不同,WebSocket 在建立连接后,允许服务器和客户端之间进行双向…...

鸿蒙进阶——驱动框架UHDF 机制核心源码解读(一)
文章大纲 引言一、uhdf 概述二、uhdf 的核心参与角色1、drivers/hdf_core/adapter/uhdf2/manager/device_manager.c1.1、drivers/hdf_core/framework/core/manager/src/devmgr_service.c#DevmgrServiceGetInstance通过objectId获取IDevmgrService实例1.2、drivers/hdf_core/fra…...
电子电路:能认为电抗也是在做功吗?
阻抗是什么,我记得在交流电路中,阻抗是电阻、电感和电容的综合作用,用Z表示,单位是欧姆。 那阻抗和做功的关系,可能需要从阻抗的组成来分析。阻抗分为电阻部分和电抗部分,也就是 Z = R + jX,其中R是电阻,X是电抗(包括感抗和容抗)。而做功可能主要和电阻有关,因为电…...
DEEPSEEK + 其他工具的玩法
1. deepseek 即梦,批量生成图片 1)给deepseek提出需求,让他生成一个海报设计框架 2)让deepseek把上面的框架转换为文生图的提示词,方便用来制作图片 3)将提示词复制到 即梦(即梦电脑…...

Idea 配合 devtools 依赖 实现热部署
核心依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency> yaml配置 spring: #…...
远程访问家里的路由器:异地访问内网设备或指定端口网址
在一些情况下,我们可能需要远程访问家里的路由器,以便进行设置调整或查看网络状态等,我们看看怎么操作? 1.开启远程访问 在路由本地电脑或手机,登录浏览器访问路由管理后台,并设置开启WEB远程访问。 2.内…...
根据参数量,如何推断需要多少数据才能够使模型得到充分训练?
✅ 一、经验法则:数据量 vs. 模型参数量 经典经验法则(适用于监督学习场景): 训练样本数 ≈ 模型参数数量的 10~100 倍对于 BERT-base(1.1亿参数),你通常需要 10亿到100亿标注样本 才能从头训…...
PycharmFlask 学习心得:路由(3-4)
对路由的理解: 用户输入网址 例如:http://localhost:5000/hello 浏览器会向这个地址发起一个 HTTP 请求(比如 GET 请求) 请求到达 Flask 的服务器 Flask 监听着某个端口(如 5000),收到请求后…...

从逻辑学视角严谨证明数据加密的数学方法与实践
文章目录 一、加密数据的数学指纹:信息论基础1.1 加密检测的核心原理1.2 香农熵:量化信息的不确定性 二、统计检验方法:从随机性到加密性2.1 卡方检验的数学原理2.2 游程检验与序列相关性2.3 NIST统计测试套件 三、加密算法的特征识别3.1 对称…...

敦煌网测评从环境搭建到风控应对,精细化运营打造安全测评体系
自养号测评,抢占流量为快速提升产品权重和销量,很多卖家常采用自己养号补单测评的方式,技术搭建需要很多要素 一、硬件参数的关联性 在我们使用设备进行注册或操作账号的过程中,系统会记录下大量的系统与网络参数,其中…...
现代化SQLite的构建之旅——解析开源项目Limbo
现代化SQLite的构建之旅——解析开源项目Limbo 在当今飞速发展的技术世界中,轻量级且功能强大的数据库已成为开发者的得力助手。当我们谈论轻量级数据库时,SQLite无疑是一个举足轻重的名字。然而,随着技术的进步,我们对数据库的需求也变得更加多样化。这正是Limbo项目诞生…...

本地分支git push 报错 fatal: The current branch XXXX has no upstream branch.
背景: 我新建了一个本地分支叫做 “新增Saas修改需求”,然后当我提交代码执行 git push时报错如下,并且代码仓库中没有我新建的“新增Saas修改需求”这个分支。 报错信息: 解决方法: 直接采用方法2 ”git push -u orig…...
人工智能100问☞第27问:神经网络与贝叶斯网络的关系?
神经网络与贝叶斯网络是两种互补的智能模型:神经网络通过多层非线性变换从数据中学习复杂模式,擅长大规模特征提取和预测,而贝叶斯网络基于概率推理建模变量间的条件依赖关系,擅长处理不确定性和因果推断。两者的融合(如贝叶斯神经网络)结合了深度学习的表征能力与概率建…...

Python----循环神经网络(WordEmbedding词嵌入)
一、编码 当我们用数字来让电脑“认识”字符或单词时,最简单的方法是为每个字符或单词分配一个唯一的编号,然后用一个长长的向量来表示它。比如,假设“我”这个字在字典中的编号是第10个,那么它的表示就是一个很多0组成的向量&…...
ElasticSearch各种查询语法示例
1. 每种查询语法的区别与优缺点 Query DSL 区别: JSON 格式的结构化查询,功能强大,支持复杂查询逻辑,适用于 Elasticsearch 的核心查询场景。优点: 灵活,功能全面,支持全文搜索、精确匹配、聚合等;可组合…...

CUDA的设备,流处理器(Streams),核,线程块(threadblock),线程,网格(gridDim),块(block)和多gpu设备同步数据概念
CUDA的设备,流处理器,核,线程块(threadblock),线程,网格(gridDim),块(block)和多gpu设备同步数据概念 CUDA的设备,流处理器,核&…...