使用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在第二个根节点下添加元素?
例: <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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |