python xml快速解析tree_python ElementTree解析xml小记

学python没多久,遇到一个解析xml的需求,边学边练,用的是ElementTree,感觉没有说的那么方便,也许E文不好,看漏api,root.findall()搞的象正则表达式,瞎了。希望知道的朋友告诉我

题目这样,比如有个xml:

Hongten

M

20

97

90

DuDu

W

21

87

96

Sum

M

19

64

98

已知某个值是19,求拥有该值的节点的父节点的所有子节点,就是这么一块:

Sum

M

19

64

98

我的代码:

#coding=utf-8

import os

import xml.etree.ElementTree as ET

filepath = 'c:\\test\\a.xml'

tree = ET.parse(filepath)

root = tree.getroot()

p_node = None

r_node = []

def func(node):

global p_node

if len(node)>0:

p_node = node

for c in node:

func(c)

else:

if node.text == '19':#值在这里在这里

r_node.append(p_node)

if __name__ == '__main__':

func(root)

if not r_node:

for n in r_node:

print '-'*10

for c in n:

print c.tag,c.text

else:

print 'not found'

输出:

----------

name Sum

gender M

age 19

score 64

score 98

[Finished in 0.1s]

先这样吧,交差!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值