打包Qt程序的脚本package.bat

要将 Qt Release 编译后的程序打包成绿色工具(即免安装、可直接拷贝运行的文件夹),需要复制程序依赖的 Qt 库、运行时库,并通过工具自动收集依赖。以下是不同场景的打包命令 / 步骤(Windows 环境):

一、基础场景:用 windeployqt 自动收集依赖(推荐)

windeployqt 是 Qt 自带的工具,能自动识别 Release 程序依赖的 Qt 库、插件、运行时文件,一键生成绿色包。

操作步骤:

编译 Release 程序:

在 Qt Creator 中选择「Release」模式,编译项目,生成 xxx.exe(路径:项目目录/build-xxx-Release/release/xxx.exe)。

打开 Qt 命令行终端:

从开始菜单启动「Qt 5.15.x (MinGW 8.1.0 64-bit)」或「Qt 5.15.x (MSVC 2019 64-bit)」终端(必须用对应编译器的终端,否则路径不对)。

执行 windeployqt 命令:

bash

运行

步骤1:切换到 Release 程序所在目录

cd /d 项目目录/build-xxx-Release/release

步骤2:执行打包命令(生成绿色包到当前目录)

windeployqt xxx.exe

补充系统运行时库:

若用 MinGW 编译:需手动拷贝 MinGW 的运行时库(路径:Qt安装目录/5.15.2/mingw81_64/bin/ 下的 libgcc_s_seh-1.dll、libstdc+±6.dll、libwinpthread-1.dll)到绿色包目录。

若用 MSVC 编译:需确保目标电脑已安装 Visual C++ 2019 运行库,或手动拷贝 MSVC 运行时库(如 vcruntime140.dll)到绿色包目录。

二、进阶场景:用脚本一键打包(含运行时 + 压缩)

可写一个批处理脚本,自动完成 windeployqt、拷贝运行时、压缩绿色包的流程:

示例脚本(package.bat ):

batch

@echo off

set "QT_PATH=D:\Qt\5.15.2\mingw81_64" # 替换为你的Qt安装路径

set "EXE_PATH=项目目录/build-xxx-Release/release/xxx.exe" # 替换为你的Release程序路径

set "OUT_DIR=绿色包输出目录" # 替换为输出目录

:: 1. 创建输出目录

mkdir "%OUT_DIR%"

:: 2. 复制Release程序到输出目录

copy "%EXE_PATH%" "%OUT_DIR%"

:: 3. 用windeployqt收集Qt依赖

call "%QT_PATH%\bin\windeployqt.exe" "%OUT_DIR%\xxx.exe" --release --no-translations

:: 4. 拷贝MinGW运行时库(MinGW编译时用)

copy "%QT_PATH%\bin\libgcc_s_seh-1.dll" "%OUT_DIR%"

copy "%QT_PATH%\bin\libstdc+±6.dll" "%OUT_DIR%"

copy "%QT_PATH%\bin\libwinpthread-1.dll" "%OUT_DIR%"

:: 5. 压缩为ZIP包(可选)

powershell Compress-Archive -Path "%OUT_DIR%*" -DestinationPath "%OUT_DIR%.zip"

echo 绿色包已生成到:%OUT_DIR%

pause

三、注意事项

插件依赖:若程序用到 Qt 插件(如数据库驱动、图像格式插件),windeployqt 会自动拷贝到 plugins 目录,无需手动处理。

第三方库:若程序依赖非 Qt 的第三方库(如 OpenCV),需手动将对应的 .dll 拷贝到绿色包目录。

无控制台窗口:若程序是 GUI 程序,编译时需在 .pro 文件中添加 CONFIG += windows(MinGW)或 CONFIG += console 改为 CONFIG -= console(MSVC),避免打包后出现控制台黑框。

总结

最便捷的方式是用 windeployqt 自动收集依赖,再补充对应编译器的运行时库,即可生成可直接拷贝运行的绿色包。

相关推荐
惊讶的猫10 小时前
多线程同步问题及解决
java·开发语言·jvm
wfsm10 小时前
工厂模式创建动态代理实现类
java·开发语言
m0_7066532311 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑11 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
不当菜虚困11 小时前
windows下HSDB导出class文件报错【java.io.IOException : 系统找不到指定的路径。】
java·开发语言
lsx20240611 小时前
Vue.js 循环语句
开发语言
m0_5613596711 小时前
嵌入式C++加密库
开发语言·c++·算法
j4455661111 小时前
C++中的职责链模式实战
开发语言·c++·算法
m0_6860416111 小时前
实时数据流处理
开发语言·c++·算法
梵刹古音11 小时前
【C语言】 字符型变量
c语言·开发语言·嵌入式