以下是XML的一部分:
<item><img src="cat.jpg" /> Picture of a cat</item>
提取标签很简单。只是做:
et = xml.etree.ElementTree.fromstring(our_xml_string)
img = et.find('img')
但是如何在它之后立即获取文本(猫的图片)?执行以下操作将返回空白字符串:
print et.text
答案 0 :(得分:22)
元素具有tail
属性 - 因此,您需要element.text
而不是element.tail
。
>>> import lxml.etree
>>> root = lxml.etree.fromstring('''<root><foo>bar</foo>baz</root>''')
>>> root[0]
<Element foo at 0x145a3c0>
>>> root[0].tail
'baz'
或者,对于您的示例:
>>> et = lxml.etree.fromstring('''<item><img src="cat.jpg" /> Picture of a cat</item>''')
>>> et.find('img').tail
' Picture of a cat'
这也适用于简单的ElementTree:
>>> import xml.etree.ElementTree
>>> xml.etree.ElementTree.fromstring(
... '''<item><img src="cat.jpg" /> Picture of a cat</item>'''
... ).find('img').tail
' Picture of a cat'