Sono in grado di ottenere il valore nel tag immagine (vedere XML sotto), ma non il tag Category. La differenza è che una è una sezione CDATA e l'altra è solo una stringa. Qualsiasi aiuto sarebbe apprezzato.xml.dom.minidom: acquisizione dei valori 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])
Qual è lo zero per? –
'getElementsByTagName' restituisce un' NodeList', '[0]' ottiene il primo elemento nell'elenco. Il Python DOM Bind richiede che '[n]' sia una scorciatoia per DOM '.item (n)'. – bobince