0

这是简单的测试项目

<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="4.0" DefaultTargets="configure">
    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
    <PropertyGroup>
        <param>var1=val1,var2=val2</param>
    </PropertyGroup>
    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
    <Target Name="configure" DependsOnTargets="" Outputs="">
        <MSBuild
            Projects="$(MSBuildProjectFullPath)"
            Properties="component=c1;$(param.Replace(',',';'))"
            Targets="process"/>
    </Target>
    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
    <Target Name="process">
        <Message Text="[$(component)][$(var1)][$(var2)]"/>
    </Target>
</Project>

我希望看到

[c1][val1][val2]

但不幸的是,msbuild 不会从我的字符串和输出中解析其他属性

[c1][val1;var2=val2][]

任何想法如何帮助 msbuild?谢谢

解决方案:使用 [MSBuild]::Unescape

<PropertyGroup>
    <p>var1=val1,var2=val2</p>
    <param>$([MSBuild]::Unescape($(p.Replace(',',';'))))</param>
</PropertyGroup>
4

1 回答 1

0

您应该使用项目组对参数和值的集合进行逻辑分组,并使用 MSBUILD 转换来获得您希望看到的输出。

<Target Name="SemiColon">
    <ItemGroup>
        <Parm Include="Parm1">
            <Value>Val1</Value>
        </Parm>
        <Parm Include="Parm2">
            <Value>Val2</Value>
        </Parm>
        <Parm Include="Parm3">
            <Value>Val3</Value>
        </Parm>
        <Parm Include="Parm4">
            <Value>Val4</Value>
        </Parm>
        <ParamLine Include="%(Parm.identity )=%(Parm.Value)" />
    </ItemGroup>
    <Message Importance="High" 
        Text="Parameter Name and Value: @(ParamLine, ';')" />
    <Message Importance="High"
        Text="Just values: @(Parm -> MetaData('Value'))" />
</Target>

ParamLine 项使用 MsBuild 转换将输出格式化为 Param=Val 格式,而第二项仅显示用分号分隔的值。

Parameter Name and Value: Parm1=Val1;Parm2=Val2;Parm3=Val3;Parm4=Val4
Just values: Val1;Val2;Val3;Val4
于 2013-06-12T21:35:16.040 回答