Python的findall()和xml
除了正则可以使用findall(), ElementTree也使用findall()
字符串对象只能使用find()
>>>xml_str="""
<a>
<b>1</b>
<b>2</b>
<c>
<d>
<b>3</b>
<b>4</b>
</d>
<e>
<b>5</b>
<b>6</b>
</e>
</c>
</a>
"""
>>> tag=xml.etree.ElementTree.fromstring(xml_str)
>>> find_tag=tag.findall("a")
>>> print find_tag
[]
/****当前节点和非当前节点的子节点(如d)直接搜索不到*****/
>>> find_tag=tag.findall("*") /**找出所有一级子节点**/
>>> print find_tag
[<Element 'b' at 0x20c77b0>, <Element 'b' at 0x20c7830>, <Element 'c' at 0x20c7850>]
>>> find_tag=tag.findall("b") /**找出一级子节点b**/
>>> print find_tag
[<Element 'b' at 0x20c77b0>, <Element 'b' at 0x20c7830>]
>>> for item in find_tag:
print item,item.text
<Element 'b' at 0x20c77b0> 1
<Element 'b' at 0x20c7830> 2
>>> find_tag=tag.findall(".//b") /**找出所有子节点b**/
>>> find_tag=tag.findall("d") /**找出节点d**/
>>> print find_tag
[]
/***想要找到节点d,需要如下写出路径,不包括当前节点***/
>>> find_tag=tag.findall("c/d")/***找出节点d***/
>>> tag_c=tag.find(".//c")
>>> find_tag=tag_c.findall(".//b") /**从c的节点开始找b**/
>>> find_tag=tag_c.findall("*//b") /**从b的上一级节点即c和d开始找b**/
>>> find_tag=tag_c.findall("d/b") /**从c下的d开始找b**/
find()和findall()
findall("*") findall("*//")和findall(".//")