在PowerShell中替换XML节点

Kei*_*ith 6 xml powershell

我有两个XML文件(File1.xml,File2.xml).File2.xml是File1.xml的子集.

File1.xml有这样的节点:

<parentnode>
    <item id="GUID1">
         <Text>Some Text</Text> 
    </item>
    <item id="GUID2">
        <Text>Here’s some more text</Text> 
    </item>
</parentnode>
Run Code Online (Sandbox Code Playgroud)

File2.xml有:

<parentnode>
    <item id="GUID1">
         <Text>Some Replacement Text</Text> 
    </item>
</parentnode>
Run Code Online (Sandbox Code Playgroud)

我想借此项目GUIDx在File1.xml,并用其替换GUIDx从File2.xml.本质上,我想在File2.xml中获取替换文本并将其插入File1.xml中的相应项目节点

我如何在PowerShell中执行此操作?

ste*_*tej 5

假设我在变量中有第一个xml $edited而在第二个中有第二个$new.然后,您可以通过ID更改ID为GUID1的项目中的值

$edited.parentnode.item | 
   ? { $_.id -eq 'guid1' } | 
   % { $_.Text = $new.parentnode.item.Text }
# and save the file
$edited.Save('d:\File1.xml')
# see the changes
gc d:\File1.xml
Run Code Online (Sandbox Code Playgroud)

如果您有更多要替换的项目,可以使用嵌套管道:

$edited = [xml]@"
<parentnode>
    <item id="GUID1"><Text>Some Text</Text></item>
    <item id="GUID2"><Text>Here’s some more text</Text></item>
    <item id="GUID3"><Text>Here’s some more text</Text></item>
    <item id="GUID10"><Text>Here’s some more text</Text></item>
</parentnode>
"@
$new = [xml] @"
<parentnode>
    <item id="GUID1"><Text>new Guid1</Text></item>
    <item id="GUID2"><Text>new Guid2</Text></item>
    <item id="GUID3"><Text>new Guid3</Text></item>
    <item id="GUID4"><Text>new Guid4</Text></item>
    <item id="GUID5"><Text>new Guid5</Text></item>
</parentnode>
"@
$new.parentnode.item | 
    % { ,($_.id,$_.Text)} | 
    % { $id,$text = $_; 
        $edited.parentnode.item | 
           ? { $_.id -eq $id } | 
           % { $_.Text = $text }
    }
Run Code Online (Sandbox Code Playgroud)

foreach循环,这里更具可读性:

foreach($i in $new.parentnode.item) { 
    $edited.parentnode.item | 
           ? { $_.id -eq $i.Id } | 
           % { $_.Text = $i.Text }
    }
Run Code Online (Sandbox Code Playgroud)

  • 加载文件时需要将文本转换为xml:`$ edited = [xml](Get-Content file2.xml); $ new = [xml](Get-Content file1.xml)` (3认同)