XML Python解析

2024-10-03 23:30:11 发布

您现在位置:Python中文网/ 问答频道 /正文

我刚开始尝试用python解析XML,我已经提供了下面的XML。我需要获取以下数据Instrmt afg=“AG”和Qty Typ=“FIN”QTYL=“149”我需要AG和149。在

我试过以下方法:

from xml.dom import minidom

xmldoc = minidom.parse(test.xml)

batch = xmldoc.getElementsByTagName('Batch')[0]

rpt = batch.getElementsByTagName('PosRpt')

for ag in rpt:
    sym = ag.getElementsByTagName('Instrmt')
    print(sym)

当我这样做时,我得到了一个DOM对象,却不知道如何得到我想要的结果。在

^{pr2}$

Tags: 数据batchxmlqtyagminidomrptsym
2条回答

要提取属性值,请使用elt.getAttribute("attribute_name"),例如:

print(sym.getAttribute("afg"), sym.getAttribute("ID"))

在您的例子中,sym仍然是一个节点列表,而不是一个节点(标记),因此您可以像这样访问列表中的特定元素,例如:

^{pr2}$

或者只是:

print sym[0].getAttribute("afg")

如果你知道列表上只有一个元素。在

您可以使用如下表达式检查标记:

e.tagName == 'Instrmt'

请看一下ElementTreeXPATH规范:

from xml.etree import ElementTree as et

data = '''\
<XML r="20030517" s="20042209" v="4.4" xr="FIA" xv="1">
- <Batch>
- <PosRpt RptID="175" BizDt="2013-01-03" ReqTyp="0" >
  <Pty ID="Ade" R="21" /> 
- <Pty ID="000" R="4">
  <Sub ID="F" Typ="29" /> 
  </Pty>
  <Instrmt afg="AG" ID="AG" Src="8" CFI="FFI" MMY="2013" Matf="2013"/> 
  <Qty Typ="AOD" QTYL="134" QTYS="0" /> 
  <Qty Typ="FIN" QTYL="149" QTYS="0" /> 
  <Amt Typ="FMTM" Amt="155065.44" /> 
  </PosRpt>
  </Batch>
  </XML>
'''

#tree = et.parse('test.xml')
tree = et.fromstring(data)

# Find the first Instrmt node anywhere in the tree
print(tree.find('.//Instrmt').attrib['afg'])

# Find a Qty node with a particular attribute.
print(tree.find(".//Qty[@Typ='FIN']").attrib['QTYL'])

输出:

^{pr2}$

相关问题 更多 >