【问题标题】:how can I loop over Api request for multiple keys and add a value to every loop?如何遍历多个键的 Api 请求并为每个循环添加一个值?
【发布时间】:2022-01-30 18:52:42
【问题描述】:

如何使用不同的 API 密钥为每个循环添加值?我正在尝试为多个商店位置编写一个简单的 ETL。我的第一次尝试是单独提取每个 API 请求。但是,这意味着我必须复制相同的代码。因此,我决定创建一个循环来遍历每个位置的键。我想用位置标识符识别每笔交易。我想在循环期间添加这个标识符。我已经尝试在 python 中解决这个问题。请提供一些反馈,如果这将是正确的方法。

all=[]
for key,value in api_data.items():
     header= {
     'Accept': 'application/json',
     'Authorization': value,}
     res=requests.get(URL,headers=header)
     res_j=res.json()
     all.extend(res_j)

【问题讨论】:

  • 您可以将 all 替换为 dict{key: res_j,...} 对。或者将api_data 中的值替换为res_j。并且不要使用all 作为名字;它是一个 python 方法。

标签: python json loops dictionary etl


【解决方案1】:

使用以授权值为关键字的字典。关联的值将是返回的 JSON。

始终检查 HTTP 响应。

在这种情况下,您只需要 api_data 字典中的 values()

这样的事情应该会有所帮助:

mydata = dict()
headers = {'Accept': 'application/json'}
for value in api_data.values():
  headers['Authorization'] = value
  (res := requests.get(URL, headers=headers)).raise_for_status()
  mydata[value] = res.json()

【讨论】:

  • 感谢您的回复。我编辑我的问题,希望能澄清结果。 @OlvinR​​oght
猜你喜欢
  • 1970-01-01
  • 2015-01-15
  • 1970-01-01
  • 2018-03-16
  • 2020-12-22
  • 1970-01-01
  • 2016-09-26
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多