我正在尝试从我的 SOAP API 响应 (XML) 中提取 sessionId。但是,无论我尝试什么,Python 仍然给我 sessionId 是空的(当我将响应打印为文本时它不是)。
我已经尝试了建议 here ,但是在这种情况下它似乎不起作用。也许因为我只能得到根,但我不确定如何从 elementroot 到 elementtree。 请参阅下面的响应 XML 和我的代码:
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<LoginResponse xmlns:ns10="http://caretrack.wirelesscar.net/reportrequest" xmlns:ns9="http://caretrack.wirelesscar.net/reportresponse" xmlns:ns8="http://caretrack.wirelesscar.net/matrisrequest" xmlns:ns7="http://caretrack.wirelesscar.net/matrisresponse" xmlns:ns6="http://caretrack.wirelesscar.net/servicerequest" xmlns:ns5="http://caretrack.wirelesscar.net/serviceresponse" xmlns:ns4="http://caretrack.wirelesscar.net/machinerequest" xmlns:ns3="http://caretrack.wirelesscar.net/machineresponse" xmlns:ns2="http://caretrack.wirelesscar.net/base" xmlns="http://caretrack.wirelesscar.net/security">
<ns2:session>
<ns2:sessionId>xxxxxx</ns2:sessionId>
</ns2:session>
</LoginResponse>
</soap:Body>
</soap:Envelope>
response = requests.post(url, data=body, headers=headers, auth=('xxxx@xxx.com', 'xxxxx'))
root = ET.fromstring(response.content)
sessionId = root.findall('.//{ns10:http://caretrack.wirelesscar.net/security}ns2:sessionId')
当我使用这段代码时,我没有收到任何错误消息,只有“[]”。也尝试了其他方法,但在那种情况下我得到“无”。
谁能告诉我我做错了什么?
最佳答案
sessionId
元素绑定(bind)到 http://caretrack.wirelesscar.net/base
命名空间。这有效(注意没有使用前缀):
sessionId = root.findall('.//{http://caretrack.wirelesscar.net/base}sessionId')
由于只有一个 sessionId
,您可以使用 find()
(返回单个元素)而不是 findall()
(它返回一个列表)。
另一种选择是创建一个带前缀的字典并在搜索方法中使用它们。参见 https://docs.python.org/3/library/xml.etree.elementtree.html#parsing-xml-with-namespaces .
关于python - 无法提取 SessionId,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57291274/