2017-04-24 97 views
1

我试图解析XML使用不同的python3模块和来自互联网的不同文章,但不成功。Python3解析xml

我有这样的XML:

<?xml version="1.0" encoding="UTF-8"?> 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/" xmlns:cwmp="urn:dslforum-org:cwmp-1-0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"><SOAP-ENV:Header/> 
<SOAP-ENV:Body SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"> 

<cwmp:GetParameterValuesResponse> 
    <ParameterList SOAP-ENC:arrayType="cwmp:ParameterValueStruct[3]"> 
     <ParameterValueStruct> 
      <Name>SOME_NAME_1_HERE</Name> 
      <Value>2</Value> 
     </ParameterValueStruct> 
     <ParameterValueStruct> 
      <Name>SOME_NAME_2_HERE</Name> 
      <Value>180</Value> 
     </ParameterValueStruct> 
     <ParameterValueStruct> 
      <Name>SOME_NAME_3_HERE</Name> 
      <Value>1800</Value> 
     </ParameterValueStruct> 
    </ParameterList> 
</cwmp:GetParameterValuesResponse> 
</SOAP-ENV:Body> 
</SOAP-ENV:Envelope> 

我需要从XML标记取数据:名称和值 它应该是这样的:

SOME_NAME_1_HERE 2 
SOME_NAME_2_HERE 180 
SOME_NAME_3_HERE 1800 

我怎样才能得到使用Python3这个值(将很好使用python默认模块 - 不是bs4)?

感谢

回答

1

使用xml.etree你可以执行简单的XPath表达式.//element_name给定上下文元素中的任何地方找到的元素:

from xml.etree import ElementTree as ET 
tree = ET.parse('path_to_your_xml.xml') 
root = tree.getroot() 

for p in root.findall('.//ParameterValueStruct'): 
    print("%s | %s" % (p.find('Name').text, p.find('Value').text)) 
+0

非常感谢您的代码。但是PRINT有些变化。 –

0

你可以尝试这样的事情:

import xml.etree.ElementTree 
e = xml.etree.ElementTree.parse('Newfile.xml').getroot() 

print(e) 
for atype in e.findall('.//ParameterValueStruct'): 
    print("%s | %s" % (atype.find('Name').text, atype.find('Value').text)) 
+0

谢谢,但你的代码什么都不打印。 '/usr/bin/python3.5 /home/ppikh/Desktop/test.py 过程,退出代码完成0' –

+0

'e.findall( '.// ParameterValueStruct')' – har07

+0

@ har07在你的情况我收到:没有为每个打印 –