Qt 项目树工程,拷贝子项目dll到子项目exe运行路径

1、项目树工程

2、项目树列表

---- BuildAll

-------- App (exe)

-------- Database (dll)

注:使用 子项目-->添加库-->内部库 的方式

3、qmake 内置的变量

cpp 复制代码
$$OUT_PWD 表示输出文件(如可执行文件、库文件等)的目录路径。
$$PWD:表示当前项目文件的目录路径。
$$TARGET:表示生成的目标文件的名称(不包括扩展名)。
$$TARGET_EXT:表示生成的目标文件的扩展名。例如,在 Windows 上,它可能为 .exe。
$$DESTDIR:表示安装目标文件时的根目录路径。默认情况下,它为空字符串,表示将目标文件安装在系统默认位置。
$$INCLUDEPATH:表示包含头文件的目录路径列表。
$$LIBS:表示要链接到目标文件中的库文件列表。
$$QMAKE_CFLAGS:表示 C 编译器选项。
$$QMAKE_CXXFLAGS:表示 C++ 编译器选项。
$$QMAKE_LFLAGS:表示链接器选项。

4、在 App 子项目的 .pro 文件下输入代码
在 App 子项目下拷贝 Database 子项目中的Database.dll文件

cpp 复制代码
#####################################################################################################
########## 功能:项目树工程,将子项目库文件(dll、lib)拷贝到子项目(exe)的运行路径下 ##########

## 注意: 在 Windows 下,路径分隔符是反斜杠 \,而不是正斜杠 /; 在非 Windows 下,可以直接用正斜杠 / ##

PROJECT_OUT_PWD = ""
win32 {
    # windows 下,将路径分隔符从 / 替换为 \
    PROJECT_OUT_PWD = $$replace(OUT_PWD, "/", "\\")
} else:unix {
    # unix 下,不用转换
    PROJECT_OUT_PWD = $$OUT_PWD
}

# 先定义变量
DEBUG_SOURCE_DLL_PATH = ""
RELEASE_SOURCE_DLL_PATH = ""
DEBUG_DEST_EXE_PATH = ""
RELEASE_DEST_EXE_PATH = ""

# 根据需要再对其赋值
win32 {
    DEBUG_SOURCE_DLL_PATH = $$PROJECT_OUT_PWD\..\Database\debug\Database.dll
    RELEASE_SOURCE_DLL_PATH = $$PROJECT_OUT_PWD\..\Database\release\Database.dll

    # 定义目标路径
    DEBUG_DEST_EXE_PATH = $$PROJECT_OUT_PWD\debug
    RELEASE_DEST_EXE_PATH = $$PROJECT_OUT_PWD\release

} else:unix {
    DEBUG_SOURCE_DLL_PATH = $$PROJECT_OUT_PWD/../Database/debug/Database.so
    RELEASE_SOURCE_DLL_PATH = $$PROJECT_OUT_PWD/../Database/release/Database.so

    # 定义目标路径
    DEBUG_DEST_EXE_PATH = $$PROJECT_OUT_PWD/debug
    RELEASE_DEST_EXE_PATH = $$PROJECT_OUT_PWD/release
}

# 根据构建模式选择复制命令
win32 {
    CONFIG(debug, debug|release) {
	# Debug 模式下的复制命令
	QMAKE_POST_LINK += copy /Y $$quote($$DEBUG_SOURCE_DLL_PATH) $$quote($$DEBUG_DEST_EXE_PATH)
    } else {
	# Release 模式下的复制命令
	QMAKE_POST_LINK += copy /Y $$quote($$RELEASE_SOURCE_DLL_PATH) $$quote($$RELEASE_DEST_EXE_PATH)
    }
} else {
    CONFIG(debug, debug|release) {
	# Debug 模式下的复制命令 (Unix-like 系统)
	QMAKE_POST_LINK += cp -f $$quote($$DEBUG_SOURCE_DLL_PATH) $$quote($$DEBUG_DEST_EXE_PATH)
    } else {
	# Release 模式下的复制命令 (Unix-like 系统)
	QMAKE_POST_LINK += cp -f $$quote($$RELEASE_SOURCE_DLL_PATH) $$quote($$RELEASE_DEST_EXE_PATH)
    }
}

#####################################################################################################

5、在 Database 子项目的 .pro 文件下输入代码
将 Database 子项目中的 Database.dll 文件拷贝到子项目App

cpp 复制代码
#####################################################################################################
############ 功能:项目树工程,将子项目库文件(dll、lib)拷贝到子项目(exe)的运行路径下 ############

##注意: 在 Windows 下,路径分隔符是反斜杠 \,而不是正斜杠 /; 在非 Windows 下,可以直接用正斜杠 / ##

# 一般情况下,修改这两个工程名即可
# 源工程名
SOURCE_PROJECT_NAME = Database
# 目标工程名
TARGET_PROJECT_NAME = App


PROJECT_OUT_PWD = ""
win32 {
    # windows 下,将路径分隔符从 / 替换为 \\
    PROJECT_OUT_PWD = $$replace(OUT_PWD, "/", "\\\\")
} else:unix {
    # unix 下,不用转换
    PROJECT_OUT_PWD = $$OUT_PWD
}

# 先定义变量
DEBUG_SOURCE_PATH = ""
RELEASE_SOURCE_PATH = ""
DEBUG_TARGET_PATH = ""
RELEASE_TARGET_PATH = ""



# 根据需要再对其赋值
win32 {

    # 源文件路径
    DEBUG_SOURCE_PATH = $$PROJECT_OUT_PWD\\debug\\$$SOURCE_PROJECT_NAME.dll
    RELEASE_SOURCE_PATH = $$PROJECT_OUT_PWD\\release\\$$SOURCE_PROJECT_NAME.dll

    # 目标路径
    DEBUG_TARGET_PATH = $$PROJECT_OUT_PWD\\..\\$$TARGET_PROJECT_NAME\\debug
    RELEASE_TARGET_PATH = $$PROJECT_OUT_PWD\\..\\$$TARGET_PROJECT_NAME\\release

} else:unix {

    # 源文件路径
    DEBUG_SOURCE_PATH = $$PROJECT_OUT_PWD/debug/$$SOURCE_PROJECT_NAME.so
    RELEASE_SOURCE_PATH = $$PROJECT_OUT_PWD/release/$$SOURCE_PROJECT_NAME.so

    # 目标路径
    DEBUG_TARGET_PATH = $$PROJECT_OUT_PWD/../$$TARGET_PROJECT_NAME/debug
    RELEASE_TARGET_PATH = $$PROJECT_OUT_PWD/../$$TARGET_PROJECT_NAME/release
}

# 根据构建模式选择复制命令
win32 {
    CONFIG(debug, debug|release) {
	# Debug 模式下的复制命令
	QMAKE_POST_LINK += copy /Y $$quote($$DEBUG_SOURCE_PATH) $$quote($$DEBUG_TARGET_PATH)
    } else {
	# Release 模式下的复制命令
	QMAKE_POST_LINK += copy /Y $$quote($$RELEASE_SOURCE_PATH) $$quote($$RELEASE_TARGET_PATH)
    }
} else {
    CONFIG(debug, debug|release) {
	# Debug 模式下的复制命令 (Unix-like 系统)
	QMAKE_POST_LINK += cp -f $$quote($$DEBUG_SOURCE_PATH) $$quote($$DEBUG_TARGET_PATH)
    } else {
	# Release 模式下的复制命令 (Unix-like 系统)
	QMAKE_POST_LINK += cp -f $$quote($$RELEASE_SOURCE_PATH) $$quote($$RELEASE_TARGET_PATH)
    }
}

#####################################################################################################

第4、第5步,选择其中一种方式即可。

相关推荐
T0uken40 分钟前
【QT Quick】C++交互:QML对象操作
c++·qt·交互
寂柒1 小时前
C++——模拟实现stack和queue
开发语言·c++·算法·list
熬夜学编程的小王1 小时前
C++类与对象深度解析(一):从抽象到实践的全面入门指南
c++·git·算法
CV工程师小林1 小时前
【算法】DFS 系列之 穷举/暴搜/深搜/回溯/剪枝(下篇)
数据结构·c++·算法·leetcode·深度优先·剪枝
zh路西法2 小时前
基于opencv-C++dnn模块推理的yolov5 onnx模型
c++·图像处理·pytorch·opencv·yolo·dnn·yolov5
-指短琴长-2 小时前
BFS解决多源最短路问题_01矩阵_C++【含多源最短路问题介绍+dist数组介绍】
c++·矩阵·宽度优先
小码农<^_^>2 小时前
c++继承(下)
开发语言·c++
盒马盒马2 小时前
Redis:cpp.redis++通用接口
数据库·c++·redis
barbyQAQ3 小时前
Qt源码阅读——事件循环
开发语言·数据库·qt
无夜_3 小时前
Prototype(原型模式)
开发语言·c++