makefile读取txt当中字符串变量和数字变量
时间: 2024-04-24 13:26:05
浏览: 82
在 Makefile 中,你可以使用 `$(shell)` [函数](https://geek.csdn.net/educolumn/ba94496e6cfa8630df5d047358ad9719?dp_token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6NDQ0MDg2MiwiZXhwIjoxNzA3MzcxOTM4LCJpYXQiOjE3MDY3NjcxMzgsInVzZXJuYW1lIjoid2VpeGluXzY4NjQ1NjQ1In0.RrTYEnMNYPC7AQdoij4SBb0kKEgHoyvF-bZOG2eGQvc&spm=1055.2569.3001.10083)来读取文本文件中的[字符串](https://geek.csdn.net/educolumn/ba94496e6cfa8630df5d047358ad9719?dp_token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6NDQ0MDg2MiwiZXhwIjoxNzA3MzcxOTM4LCJpYXQiOjE3MDY3NjcxMzgsInVzZXJuYW1lIjoid2VpeGluXzY4NjQ1NjQ1In0.RrTYEnMNYPC7AQdoij4SBb0kKEgHoyvF-bZOG2eGQvc&spm=1055.2569.3001.10083)变量和数字变量。下面是一个示例:
假设有一个名为 `variables.txt` 的文本文件,内容如下:
VAR1 = Hello
VAR2 = 42
你可以使用以下方式在 Makefile 中读取这些变量:
```makefile
include variables.txt
target:
@echo "[string](https://geek.csdn.net/edu/8802d631b97a4a6af1f4d0bbf8527465?dp_token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6NDQ0MDg2MiwiZXhwIjoxNzA3MzcxOTM4LCJpYXQiOjE3MDY3NjcxMzgsInVzZXJuYW1lIjoid2VpeGluXzY4NjQ1NjQ1In0.RrTYEnMNYPC7AQdoij4SBb0kKEgHoyvF-bZOG2eGQvc&spm=1055.2569.3001.10083) variable: $(VAR1)"
@echo "Numeric variable: $(VAR2)"
在上述示例中,我们通过 `include` 命令将 `variables.txt` 文件包含到 Makefile 中,以便在 Makefile 中使用其中定义的变量。
然后,在[目标](https://geek.csdn.net/educolumn/06c7a9ffb1969a0ad080048a16f82c4e?spm=1055.2569.3001.10083)规则中,我们使用 `$(VAR1)` 和 `$(VAR2)` 分别引用了从文件中读取的[字符串](https://geek.csdn.net/educolumn/ba94496e6cfa8630df5d047358ad9719?dp_token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6NDQ0MDg2MiwiZXhwIjoxNzA3MzcxOTM4LCJpYXQiOjE3MDY3NjcxMzgsInVzZXJuYW1lIjoid2VpeGluXzY4NjQ1NjQ1In0.RrTYEnMNYPC7AQdoij4SBb0kKEgHoyvF-bZOG2eGQvc&spm=1055.2569.3001.10083)变量和数字变量。
当你运行 Makefile 时,它会读取 `variables.txt` 文件并将其中的变量值插入到相应的位置。
请确保 `variables.txt` 文件与 Makefile 在同一目录下,并根据实际的文件路径进行相应的调整。
相关问题
makefile的正则匹配字符串和数字
在 Makefile 中,你可以使用 `$(filter)` 函数来进行基本的字符串和数字的正则匹配。
以下是一个示例:
```makefile
strings := apple banana cherry
numbers := 123 456 789
filtered_strings := $(fi
```