Я пытаюсь перебрать один файл XML в Python с ElementTree, изменить один атрибут в теге, а затем вставить этот тег в другой тег в другом файле, код ниже:
import xml.etree.ElementTree as ET
tree = ET.parse('original_file.xml')
root = tree.getroot()
cnt = 1
exact = ET.Element("eExact")
glentries = ET.SubElement(exact, "GLEntries")
glentry = ET.SubElement(glentries, "GLEntry", status="E", entry="194100751")
ET.SubElement(glentry, "DocumentDate").text = "31032019"
ET.SubElement(glentry, "Description").text = "TEST"
ET.SubElement(glentry, "Journal", code="41", type="M")
for child in root.iter('FinEntryLine'):
child.attrib["number"] = cnt
ET.SubElement(glentry, child)
cnt += 1
tree = ET.ElementTree(exact)
tree.write("output_file.xml")
Однако это не работает, потому что ElemntTree и SubElement сообщают, что они не могут сериализоваться. Есть ли другой способ сделать это, но мне не нужно итерировать все подтеги "child"?
Входной файл:
<eExact>
<GLEntries>
<GLEntry status="E" entry="194100751">
<DocumentDate>31032019</DocumentDate>
<Description>TEST</Description>
<Journal code="41" type="M"></Journal>
<FinEntryLine number="83932" type="N" subtype="N">
<Description>01032019 GWPC 1900005105</Description>
</FinEntryLine>
<FinEntryLine number="98457" type="N" subtype="N">
<Description>01032019 GWPC 1900005105</Description>
</FinEntryLine>
</GLEntry>
</GLEntries>
</eExact>
Вывод должен просто поменять номер тега на последовательность, начиная с 1.