Usando o PowerShell para editar vários arquivos XML
-
22-09-2019 - |
Pergunta
Como posso obter uma lista de vários arquivos XML de um diretório especificado e para cada arquivo adicionar um elemento no segundo nó raiz usando o PowerShell?
Exemplo: eu quero adicionar <LastName>SomeName</LastName>
dentro do primeiro <Names>
elemento:
<People>
<Names>
<FirstName>someFirstName</FirstName>
</Names>
<Names>
<FirstName>myFirstName</FirstName>
<Address>SomeAddress</Address>
</Names>
</People>
Se tornará:
<People>
<Names>
<LastName>SomeName</LastName>
<FirstName>someFirstName</FirstName>
</Names>
<Names>
<FirstName>myFirstName</FirstName>
<Address>SomeAddress</Address>
</Names>
</People>
Solução
Você pode fazer isso usando CreateElement
e AppendChild
método
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)
}
Caso você execute o PowerShell v2, você não precisa usar a propriedade PsBase
:
$lastName.InnerText = 'SomeName'
Existem com certeza outras maneiras, mas essa é bastante fácil.
Caso o nó seja mais profundo em XML, você pode usar o XPath como este (ambos encontram primeiro Names
nó):
$node = (Select-Xml -Xml $x -XPath '//Names[1]').Node
$node = (Select-Xml -Xml $x -XPath '//Names[position()=1]').Node
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow