requests
nie obsługuje analizowania odpowiedzi XML, nie. Odpowiedzi XML mają znacznie bardziej złożony charakter niż odpowiedzi JSON, a sposób serializacji danych XML do struktur Pythona nie jest tak prosty.
Python zawiera wbudowane parsery XML. Polecam korzystanie z API ElementTree :
import requests
from xml.etree import ElementTree
response = requests.get(url)
tree = ElementTree.fromstring(response.content)
lub, jeśli odpowiedź jest szczególnie duża, zastosuj podejście przyrostowe:
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`
Zewnętrzny projekt lxml opiera się na tym samym interfejsie API, aby zapewnić więcej funkcji i możliwości.