MSBuild 中的特殊字符($ @ % 等):含义、用法以及转义

2023-10-22 09:56:19 浏览数 (2)

在 MSBuild 中有一些特殊字符,如 $ @ % ' 等,本文介绍他们的含义,如何使用他们,以及你真的需要这些字符的时候如何编写他们。


特殊字符

MSBuild 中有这些特殊字符:

  • $
  • @
  • %
  • '
  • ;
  • ?
  • *

含义和用法

$

引用一个属性或者环境变量。

1 2 3 4 5 6

<Project> <ItemGroup> <TargetFramework>netcoreapp3.0</TargetFramework> <OutputPath>bin$(Configuration)</OutputPath> </ItemGroup> </Project>

比如以下两篇博客列出了一些最典型的使用场景。

  • 如何更精准地设置 C# / .NET Core 项目的输出路径?(包括添加和删除各种前后缀)
  • 在 csproj 文件中使用系统环境变量的值(示例将 dll 生成到 AppData 目录下)

@

引用一个集合。

1 2 3 4

<Target Name="WalterlvDemoTarget" BeforeTargets="CoreCompile"> <Message Text="References:" /> <Message Text="@(Reference)" /> </Target>

比如以下两篇博客列出了一些最典型的使用场景:

  • 在 Target 中获取项目引用的所有依赖(dll/NuGet/Project)的路径
  • 在制作跨平台的 NuGet 工具包时,如何将工具(exe/dll)的所有依赖一并放入包中

%

引用集合中某一个项的某个属性。

1 2 3 4 5 6

<Target Name="Xxx" AfterTargets="AfterBuild"> <ItemGroup> <Walterlv Include="@(Compile)=%(Compile.CopyToOutputDirectory)" /> </ItemGroup> <Warning Text="@(Walterlv)" /> </Target>

比如下面两篇博客列出了此字符的一些使用:

  • 在项目文件 csproj 中或者 MSBuild 的 Target 中使用 % 引用集合中每一项的属性

'

在形成一个字符串的时候,会使用到此字符。

下面这篇博客列出了此字符的一些使用:

  • MSBuild 如何编写带条件的属性、集合和任务 Condition?

;

如果存在分号,那么在形成一个集合的时候,会被识别为集合中的各个项之间的分隔符。

有时候你真的需要分号而不是作为分隔符的时候,需要进行转义:

  • Roslyn how to use WriteLinesToFile to write the semicolons to file - 林德熙

?*

作为通配符使用。一个 * 表示文件或者文件夹通配符,而 ** 则表示任意层级的文件或文件夹。

下面这篇博客虽然古老,却也说明了其用法:

  • 为 Visual Studio 使用通配符批量添加项目文件

转义

在 MSBuild 中,由于这些特殊字符其实非常常见,所以与一些已有的值很容易冲突,所以需要转义。

转义可以使用 ASCII 编码:

  • $ - $
  • @ - @
  • % - %
  • ' - '
  • ; - ;
  • ? - ?
  • * - *

转义方法一:

1

<Compile Include="Walterlv1;Walterlv2.cs"/>

这样得到的将是一个名字为 Walterlv1;Walterlv2.cs 的文件,而不是两个文件。

转义方法二:

1

<Compile Include="$([MSBuild]::Escape('Walterlv1;Walterlv2.cs'))" />

详细方法可参见:

  • Roslyn how to use WriteLinesToFile to write the semicolons to file - 林德熙

参考资料

  • MSBuild Special Characters - Visual Studio - Microsoft Docs
  • How to: Escape Special Characters in MSBuild - Visual Studio - Microsoft Docs

本文会经常更新,请阅读原文: https://blog.walterlv.com/post/msbuild-special-characters.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 ([email protected]) 。

0 人点赞