Python获取任意xml节点值的方法
更新时间:2015年05月05日 10:13:22 作者:鸪斑兔
这篇文章主要介绍了Python获取任意xml节点值的方法,涉及Python操作XML节点的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
本文实例讲述了Python获取任意xml节点值的方法。分享给大家供大家参考。具体实现方法如下:
# -*- coding: utf-8 -*-
import xml.dom.minidom
ELEMENT_NODE = xml.dom.Node.ELEMENT_NODE
class SimpleXmlGetter(object):
def __init__(self, data):
if type(data) == str:
self.root = xml.dom.minidom.parse(data)
else:
self.root = data
def __getattr__(self, name): #support . operation
if name == 'data':
return self.root.firstChild.data
for c in self.root.childNodes:
if c.nodeType == ELEMENT_NODE and c.tagName == name:
return SimpleXmlGetter(c)
def __getitem__(self, index): #support [] operation
eNodes = [ e for e in self.root.parentNode.childNodes
if e.nodeType == ELEMENT_NODE and e.tagName == self.root.tagName]
return SimpleXmlGetter(eNodes[index])
def __call__(self, *args, **kwargs): #support () openration, for query conditions
for e in self.root.parentNode.childNodes:
if e.nodeType == ELEMENT_NODE:
for key in kwargs.keys():
if e.getAttribute(key) != kwargs[key]:
break
else:
return SimpleXmlGetter(e)
if __name__ == "__main__":
x = SimpleXmlGetter("sysd.xml")
print x.sysd.sysagent.param[2].data
print x.sysd.sysagent.param(name="querytimeout", type="second").data
希望本文所述对大家的Python程序设计有所帮助。
相关文章
python3实现网络爬虫之BeautifulSoup使用详解
这篇文章主要介绍了python3实现网络爬虫之BeautifulSoup使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-12-12
python中Selenium+Webdriver实现自动化登录
本文主要介绍了python中Selenium+Webdriver实现自动化登录,包括测试环境的搭建、代码编写、以及注意事项等,具有一定的参考价值,感兴趣的可以了解一下2023-09-09


最新评论