问题
I've read the remove
example here and the example here is not applicable to me.
My xml file reads:
<A>
<B>some text</B>
<B>other text</B>
<B>more text</B>
</A>
What I want to do is to remove the second <B></B>
from the xml. I do not know what text it holds. But I have the index of the <B></B>
, say index = 1, which means I want to remove the second element (or node).
I have a code like this:
F = open('example.xml')
self.tree = parse(F)
self.root = self.tree.getroot()
F.close()
So in this case what I want to remove is self.root[1]
.
How can this be implemented using ElementTree?
Edit: Made my question more clear and specific.
回答1:
In [1]: import xml.etree.ElementTree as ET
In [2]: xmlstr=\
...: """
...: <A>
...: <B>some text</B>
...: <B>other text</B>
...: <B>more text</B>
...: </A>
...: """
In [3]: tree=ET.fromstring(xmlstr)
In [4]: tree.remove(tree.findall('.//B')[1])
回答2:
You guys are not straight to the point. I've combined my knowledge with the answers here and came out with this:
for i, child in enumerate(self.root):
if path == i:
self.root.remove(child)
break
where path
is the index of the item I want to remove.
来源:https://stackoverflow.com/questions/14051422/how-do-i-remove-a-node-in-xml-using-elementtree-in-python