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>
Foi útil?

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
scroll top