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响应-
<?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”属性
这样,您可以通过XPATH从根/父元素中搜索xml中的任何元素。
附带说明:我并不特别喜欢使用pop方法从单个项目列表中删除该项目。所以如果其他人有更好的办法,请告诉我。到目前为止,我认为:
1)elm=next(iter(response.xpath('/response/data/testId'))
2)简单地把它放在一个列表中,这样它就可以用作stararg
使用以下方法从响应中收集testId:
前几天我在饲料里发现了这篇文章,也许可以满足你的需要。我略读了一下,但一般来说,包解析xml数据并将标记/属性/值转换为字典。此外,作者还指出,它还维护了xml的嵌套结构。
https://www.oreilly.com/learning/jxmlease-python-xml-conversion-data-structures
对于您的用例。
相关问题 更多 >
编程相关推荐