Python解析xml文件

1. 背景说明?

  解析 xml 格式的文件有多种方法, 这里只介绍使用 xml.etree.ElementTree 这种解析方式.

2. ElementTree 和 cElementTree 的区别?

  ElementTree在 Python 标准库中有两种实现。一种是纯 Python 实现例如 xml.etree.ElementTree ,另外一种是速度快一点的 xml.etree.cElementTree 。你要记住: 尽量使用 C 语言实现的那种,因为它速度更快,而且消耗的内存更少。

  注意: 开发的时候为了调试方便, 可以使用 ElementTree .

3. 解析方式?

  导入包:  python3.3之后ElementTree模块会自动寻找可用的C库来加快速度

try:
    import xml.etree.cElementTree as et
except ImportError:
    import xml.etree.ElementTree as et

  3.1 方式一: 读取 xml 文件成 xml 对象

# 从某文件解析成 xml 对象:
tree_obj = et.parse( "city_info.xml" )

# 获取根节点元素
root = tree_obj.getroot()

  3.2 方式二: 读取 xml 字符串成 xml 对象

# 注意: xml 格式开头的 <?xml version......  一定不能有空格, 否则报错!!!
xml_text = """<?xml version="1.0" encoding="UTF-8"?>
<struts>
    <action name="login" class="com.coderising.litestruts.LoginAction">
        <result name="success">homepage.jsp</result>
        <result name="fail">showLogin.jsp</result>
    </action>
    <action name="logout" class="com.coderising.litestruts.LogoutAction">
       <result name="success">welcome.jsp</result>
       <result name="error">error.jsp</result>
    </action>
</struts>
"""

# 获取很节点元素
root = et.fromstring(xml_text)

  3.3 解析各元素获取信息

  获取属性值和文本信息

# xml_text, 即上面的xml字符串

root = et.fromstring(xml_text)
for action in root.iter("action"):
    act_name = action.attrib.get("name")    # 获取属性值
    class_info = action.get("class")        # 同样也是获取标签属性值, 上面的简写方式
    for result in action.iter("result"):
        res_name = result.get("name")
        res_text = result.text              # 获取标签文本信息

  find 方法 + xpath 解析式 (注意: xpath解析式不支持绝对路径, 仅支持相对路径, 比如 "./")

    find(): 查找满足条件的第一个标签

    findall(): 查找满足条件的所有标签

root = et.fromstring(xml_text)

# find() 查找第一个标签
action = root.find(".//action/result[2]")
print(action.get("name"))        # fail
print(action.text)               # result 1.2 result 1.2 result 1.2 result 1.2


# findall() 查找所有标签
actions = root.findall(".//action/result")
for action in actions:
    ac_name = action.get("name")
    ac_text = action.text
原文地址:https://www.cnblogs.com/bk9527/p/11437539.html