我非常喜欢requests
包和它处理JSON响应的舒适方式。
不幸的是,我不知道我是否也能处理XML响应。有没有人有使用requests
包处理XML响应的经验?是否有必要包含另一个用于XML解码的包?
发布于 2013-08-19 15:33:55
requests
不处理解析XML响应,不。XML响应本质上比JSON响应复杂得多,如何将XML数据序列化为Python结构并不那么简单。
Python附带了内置的XML解析器。我建议您使用ElementTree API
import requests
from xml.etree import ElementTree
response = requests.get(url)
tree = ElementTree.fromstring(response.content)
或者,如果响应特别大,则使用增量方法:
response = requests.get(url, stream=True)
# if the server sent a Gzip or Deflate compressed response, decompress
# as we read the raw stream:
response.raw.decode_content = True
events = ElementTree.iterparse(response.raw)
for event, elem in events:
# do something with `elem`
外部lxml project构建在相同的API之上,为您提供了更多的功能和功能。
发布于 2021-04-28 15:54:45
一种简单得多的方法是使用xmltodict包将XML转换为dict
response = requests.get('http://blabla.com')
dict_data = xmltodict.parse(response.content)
现在,dict_data
,它只是一本Python字典。
你可以用pip安装它:pip install xmltodict
https://stackoverflow.com/questions/18308529
复制相似问题