使用Python从GET调用中保存XML响应

时间:2015-04-22 23:08:38

标签: python xml save python-requests parsexml

我尝试使用API​​创建实时报告,该API允许我获取所需的数据并以XML格式返回。我想知道的是,收到响应后,如何在本地将其保存到.xml文件中?或者缓存它,这样我就可以在解析响应之前解析它。

import requests
r = requests.get('url',  auth=('user', 'pass'))

我使用请求,因为在我看来,这是进行GET调用的最简单方法。另外,这是我的第一个问题,我几乎没有开始学习Python,如果你们有一点耐心,我会很感激。谢谢。

我正在查看类似的问题,但对于JSON,不确定它是否会起作用,https://stackoverflow.com/a/17519020/4821590

import requests
import json
solditems = requests.get('https://github.com/timeline.json') # (your url)
data = solditems.json()
with open('data.json', 'w') as f:
    json.dump(data, f)

2 个答案:

答案 0 :(得分:14)

如果您希望能够在使用它之前解析返回的XML,xml tree就是您的朋友。

import requests
import xml.etree.ElementTree as ET

r = requests.get('url',  auth=('user', 'pass'))
tree = ET.parse(r.text)
root = tree.getroot()

否则,正如jordanm评论的那样,您可以将其保存到文件中并完成它。

with open('data.xml', 'w') as f:
    f.write(r.text)

答案 1 :(得分:5)

与Python3(至少3.6版)相关的注释很少:

1)当对请求使用xml.etree.ElementTree时,使用fromstring而不是解析。 r.text返回一个字符串,而xml.etree.ElementTree.parse用于文件

import requests
import xml.etree.ElementTree as ET

r = requests.get("https://xml.returning.uri")
root = ET.fromstring(r.text)

2)这将创建一个元素对象作为根(不再有树)。因此,要写回它,您需要将其做成一棵树:

tree = ET.ElementTree(root)
tree.write("file.xml")

来自文档

  

xml.etree.ElementTree.parse(source,parser = None)   将XML部分解析为元素树。源是包含XML数据的文件名或文件对象。

     

xml.etree.ElementTree.fromstring(文本)   从字符串常量解析XML部分。与XML()相同。 text是包含XML数据的字符串。返回一个Element实例