首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用基于条件的Powershell在xml中追加属性

使用基于条件的Powershell在xml中追加属性
EN

Stack Overflow用户
提问于 2020-02-13 18:10:30
回答 1查看 37关注 0票数 0

下面是我的XML代码:

代码语言:javascript
复制
<office>
<staff branch=" Culver City" Type="Implementation">
    <employee >
        <Name>Geoff Lyle</Name>
        <function>Consultant</function>
        <age>40</age>
    </employee>

    <employee>
        <Name>Kevin</Name>
        <function>Consultant</function>
        <age>39</age>
    </employee>

    <employee>
        <Name>David</Name>
        <function>Consultant</function>
        <age>22</age>
    </employee>

</staff>
</office>

如果年龄超过40岁,如何使用powershell将“已激发”属性附加到该属性。我试着写了一个脚本,如下所示。有谁能帮我学语法吗?

代码语言:javascript
复制
$xml = New-Object XML
$xml.Load("C:\Users\rparpani\Desktop\test.xml")

$nodes = $xml.SelectNodes("/office/staff/employee")
$node2 = $xml| Select - XML -XPath "//employee[@age]"
foreach($node in $nodes)
{
if($node2 ge 40){
$node.SetAttribute("status", "fired");
}

}

$xml.Save("C:\Users\rparpani\Desktop\test.xml")
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-13 18:48:00

我将使用XPath通过age值过滤XML节点:

代码语言:javascript
复制
$xmlPath = "C:\Users\rparpani\Desktop\test.xml"
$xml = New-Object XML
$xml.Load($xmlPath)

$nodes = $xml.SelectNodes("/office/staff/employee[number(age) >= 40]")
foreach ($node in $nodes) {
  $node.SetAttribute("status", "fired")
}

$xml.Save($xmlPath)

如果您使用if ($node.age -ge 40) { ... },您的方法就可以工作,但是为什么不使用XPath来过滤节点,同时使用XPath检索节点呢?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60214082

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档