Добавить атрибут в xml с помощью Powershell на основе условия - PullRequest
0 голосов
/ 13 февраля 2020

Ниже приведен мой XML код:

<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>

Как использовать powershell для добавления атрибута «запущен», если возраст старше 40 лет. Я попытался написать скрипт, как показано ниже. Может кто-нибудь, пожалуйста, помогите мне с моим синтаксисом

$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")

1 Ответ

0 голосов
/ 13 февраля 2020

Я бы использовал XPath для фильтрации узлов XML по значению age:

$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.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...