Puedo obtener el valor en la etiqueta de imagen (ver XML a continuación), pero no la etiqueta de Categoría. La diferencia es que una es una sección CDATA y la otra es solo una cadena. Cualquier ayuda sería apreciada.xml.dom.minidom: Obtener valores de CDATA
from xml.dom import minidom
xml = """<?xml version="1.0" ?>
<ProductData>
<ITEM Id="0471195">
<Category>
<![CDATA[Homogenizers]]>
</Category>
<Image>
0471195.jpg
</Image>
</ITEM>
<ITEM Id="0471195">
<Category>
<![CDATA[Homogenizers]]>
</Category>
<Image>
0471196.jpg
</Image>
</ITEM>
</ProductData>
"""
bad_xml_item_count = 0
data = {}
xml_data = minidom.parseString(xml).getElementsByTagName('ProductData')
parts = xml_data[0].getElementsByTagName('ITEM')
for p in parts:
try:
part_id = p.attributes['Id'].value.strip()
except(KeyError):
bad_xml_item_count += 1
continue
if not part_id:
bad_xml_item_count += 1
continue
part_image = p.getElementsByTagName('Image')[0].firstChild.nodeValue.strip()
part_category = p.getElementsByTagName('Category')[0].firstChild.data.strip()
print '\t'.join([part_id, part_category, part_image])
Cuál es el cero para? –
'getElementsByTagName' devuelve un' NodeList', '[0]' obtiene el primer elemento de la lista. Los enlaces DOM de Python requieren que '[n]' sea un atajo para DOM '.item (n)'. – bobince