如何从指定目录获取多个
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 举报,一经查实,本站将立刻删除。