Search code examples
xmlpowershellxpathxmldocument

Powershell select parent xml node based on child node value and add child element


see the following xml

    <catalog>
        <books>
           <book id="bk101">
              <author>Gambardella, Matthew</author>
              <title>XML Developer's Guide</title>
              <genre>Computer</genre>
              <price>44.95</price>
              <publish_date>2000-10-01</publish_date>
              <description>An in-depth look at creating applications 
              with XML.</description>
           </book>
           <book id="bk102">
              <author>Ralls, Kim</author>
              <title>Midnight Rain</title>
              <genre>Fantasy</genre>
              <price>5.95</price>
              <publish_date>2000-12-16</publish_date>
              <description>A former architect battles corporate zombies, 
              an evil sorceress, and her own childhood to become queen 
              of the world.</description>
           </book>
           <book id="bk103">
              <author>Corets, Eva</author>
              <title>Maeve Ascendant</title>
              <genre>Fantasy</genre>
              <price>5.95</price>
              <publish_date>2000-11-17</publish_date>
              <description>After the collapse of a nanotechnology 
              society in England, the young survivors lay the 
              foundation for a new society.</description>
           </book>
       </books>
    </catalog>

I want to, in powershell, select the book node/element where the author is Corets,Eva and then add a child element of book, another element(sibling of price, comes directly after price) of , say, length. along with a new value for length of say, '456'

So the (partial) xml code for the book element after Ive run the code would look like:

<catalog>
    <books>
       <book id="bk103">
          <author>Corets, Eva</author>
          <title>Maeve Ascendant</title>
          <genre>Fantasy</genre>
          <price>5.95</price>
          <length>456</length>        
          <publish_date>2000-11-17</publish_date>
          <description>After the collapse of a nanotechnology 
          society in England, the young survivors lay the 
          foundation for a new society.</description>
       </book>
       <book>
        ....
       </book>
    </books>
<etc>

Can anyone assist? Been stuck for two days now. Thanks


Solution

  • You can use the XMLNode.InsertAfter method.

    Example:

    [xml]$books = Get-Content .\books.xml
    $corets = $books.catalog.books.book | Where-Object { $_.author -eq 'Corets, Eva' }
    $coretsPrice = $corets.SelectSingleNode('price')
    $coretsLength = $books.CreateElement('length')
    $coretsLength.InnerText = 495
    $corets.InsertAfter($coretsLength, $coretsPrice)