Python-如何解析xml响应并在变量中存储元素值?

2024-04-26 10:58:34 发布

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

enter code here我正在从API调用获取XML响应。

我需要这个响应的“testId”属性值,请帮助我。

   r=requests.get( myconfig.URL_webpagetest + "?url=" + testurl + "&f=xml&k=" + myconfig.apikey_webpagetest )

    xmltxt=r.content

    print (xmltxt)

    testId = XML (xmltxt).find("testId").text

    r=requests.get("http://www.webpagetest.org/testStatus.php?f=xml&test=" + testId )

xml响应-

enter image description here

<?xml version="1.0" encoding="UTF-8"?>
<response>
<statusCode>200</statusCode>
<statusText>Ok</statusText>
<data>
<testId>180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</testId>
<ownerKey>dfc65d98de13c4770e528ef5b65e9629a52595e9</ownerKey>
<jsonUrl>http://www.webpagetest.org/jsonResult.php?test=180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</jsonUrl>
</data>
</response>

以下错误正在响应-

回溯(最近一次呼叫时间): 文件“/pagePerformance.py”,第52行,in testId=XML(xmltxt).find(“testId”).text AttributeError:“NoneType”对象没有“text”属性


Tags: textorghttpget属性wwwxmlfind
3条回答
from lxml.etree import fromstring

string = '<?xml version="1.0" encoding="UTF-8"?> <response> <statusCode>200</statusCode> <statusText>Ok</statusText> <data><testId>180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</testId> <ownerKey>dfc65d98de13c4770e528ef5b65e9629a52595e9</ownerKey> <jsonUrl>http://www.webpagetest.org/jsonResult.php?test=180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</jsonUrl> </data> </response>'

response = fromstring(string.encode('utf-8'))
elm = response.xpath('/response/data/testId').pop()
testId = elm.text

这样,您可以通过XPATH从根/父元素中搜索xml中的任何元素。

附带说明:我并不特别喜欢使用pop方法从单个项目列表中删除该项目。所以如果其他人有更好的办法,请告诉我。到目前为止,我认为:

1)elm=next(iter(response.xpath('/response/data/testId'))

2)简单地把它放在一个列表中,这样它就可以用作stararg

使用以下方法从响应中收集testId:

import xml.etree.ElementTree as ET

response_xml_as_string = "xml response string from API"
responseXml = ET.fromstring(response_xml_as_string)
testId = responseXml.find('data').find('testId')
print testId.text

前几天我在饲料里发现了这篇文章,也许可以满足你的需要。我略读了一下,但一般来说,包解析xml数据并将标记/属性/值转换为字典。此外,作者还指出,它还维护了xml的嵌套结构。

https://www.oreilly.com/learning/jxmlease-python-xml-conversion-data-structures

对于您的用例。

>>> xml = '<?xml version="1.0" encoding="UTF-8"?> <response> <statusCode>200</statusCode> <statusText>Ok</statusText> <data> <testId>180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</testId> <ownerKey>dfc65d98de13c4770e528ef5b65e9629a52595e9</ownerKey> <jsonUrl>http://www.webpagetest.org/jsonResult.php?test=180523_YM_054fd7d84fd4ea7aed237f87289e0c7c</jsonUrl> </data> </response>'

>>> root = jxmlease.parse(xml)
>>> testid = root['response']['data']['testId'].get_cdata()
>>> print(testid)
>>> '180523_YM_054fd7d84fd4ea7aed237f87289e0c7c'

相关问题 更多 >