微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用powershell编辑多个XML文件

如何从指定目录获取多个 XML文件的列表,并为每个文件使用powershell在第二个根节点下添加元素?

例:
我想添加< LastName> SomeName< / LastName>在FirsT< Names>内元件:

<People>
  <Names>
      <FirstName>someFirstName</FirstName>
  </Names>
  <Names>
      <FirstName>myFirstName</FirstName>
      <Address>SomeAddress</Address>
  </Names>
</People>

会变成:

<People>
  <Names>
      <LastName>SomeName</LastName>
      <FirstName>someFirstName</FirstName>
  </Names>
  <Names>
      <FirstName>myFirstName</FirstName>
      <Address>SomeAddress</Address>
  </Names>
</People>

解决方法

您可以使用CreateElement和AppendChild方法执行此操作

Get-ChildItem c:\temp\ *.xml | 
    % { 
        $xml      = [xml](Get-Content $_.fullname)
        $lastName = $xml.CreateElement('LastName')
        $lastName.PsBase.InnerText = 'SomeName'
        $null     = $xml.People.Names[0].AppendChild($lastName)
        $xml.Save($_.FullName)
    }

如果您运行PowerShell V2,则不需要使用属性PsBase:

$lastName.InnerText = 'SomeName'

肯定有其他方法,但这很容易.

如果节点在xml中更深,你可以像这样使用Xpath(都找到第一个Names节点):

$node = (@R_468_3270@ -Xml $x -XPath '//Names[1]').Node
$node = (@R_468_3270@ -Xml $x -XPath '//Names[position()=1]').Node

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。