Search code examples
pythonpython-3.xxml-parsingminidom

Parsing XML using minidom in Python


I'm new to Python and need a little advice on one of my project from the experts.

I have a xml file that i need to parse and then sort . Below is the example of the xml file

<Product_Key Name="Visio Professional 2002" KeyRetrievalNote="">
    <Key ID=“XXX” Type="Static Activation Key">12345-67890</Key>
</Product_Key>


<Product_Key Name="Visio Professional 2008" KeyRetrievalNote="">
    <Key ID=“XXX” Type="Static Activation Key">23456-78901</Key>
</Product_Key>


<Product_Key Name="Visio Professional 2012" KeyRetrievalNote="">
    <Key ID=“XXX” Type="Static Activation Key">34567-89012</Key>
</Product_Key>


<Product_Key Name="Visio Professional 2016” KeyRetrievalNote="">
    <Key ID=“XXX” Type="Static Activation Key">45678-90123</Key>
</Product_Key>

Below is the output that i'm trying to achieve

Visio Professional 2002:   12345-67890
Visio Professional 2008:   23456-78901
Visio Professional 2012:   34567-89012
Visio Professional 2016:   45678-90123

I'm trying to get the name of the product and in front of it the corresponding product key.

I can get the output like below however that is not what I'm looking for.

Visio Professional 2002
Visio Professional 2008
Visio Professional 2012
Visio Professional 2016 
12345-67890
23456-78901
34567-89012
45678-90123

The snip of the code that i used is below .

import xml.dom.minidom

def main():
  doc = xml.dom.minidom.parse("keysexport.xml")
  names = doc.getElementsByTagName("Product_Key")
  keys = doc.getElementsByTagName("Key")

  for name in names:
    print(name.getAttribute("Name"))

  for key in keys:
    print(key.firstChild.nodeValue)

if __name__ == "__main__":
  main();

Solution

  • You have done most of the work by yourself. Congratulations.

    There are many ways to achieve your final goal, one of them is the following: Now that you obtained the names and keys list, you can combine them to construct a dictionary, and then iterate over the dictionary to get the suitable output you are looking for.

    So your program could look like this:

    import xml.dom.minidom
    
    def main():
      doc = xml.dom.minidom.parse("keysexport.xml")
      names = doc.getElementsByTagName("Product_Key")
      keys = doc.getElementsByTagName("Key")
      #Use the previous lists to create a dictionary
      products = dict(zip(names, keys)) 
      #Loop over the dictionary of products and display the couple key: value
      for product_key, product_value in products.items():
          print('{}:  {}'.format(product_key.getAttribute('Name'), product_value.firstChild.nodeValue))
    
    
    if __name__ == "__main__":
      main()
    

    Demo:

    >>> names = xmldoc.getElementsByTagName("Product_Key")
    >>> keys = xmldoc.getElementsByTagName("Key")
    >>> products = dict(zip(names, keys))
    >>> for product_key, product_value in products.items():
    ...     print('{}:  {}'.format(product_key.getAttribute('Name'), product_value.firstChild.nodeValue))
    ... 
    Visio Professional 2002:  12345-67890
    Visio Professional 2008:  23456-78901
    Visio Professional 2012:  34567-89012
    Visio Professional 2016:  45678-90123