加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用powershell编辑多个XML文件

发布时间:2020-12-16 23:14:53 所属栏目:百科 来源:网络整理
导读:如何从指定目录获取多个 XML文件的列表,并为每个文件使用powershell在第二个根节点下添加元素? 例: 我想添加 LastName SomeName / LastName在FIRST Names内元件: People Names FirstNamesomeFirstName/FirstName /Names Names FirstNamemyFirstName/First
如何从指定目录获取多个 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 = (Select-Xml -Xml $x -XPath '//Names[1]').Node
$node = (Select-Xml -Xml $x -XPath '//Names[position()=1]').Node

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读