我尝试使用Python从Postman中的API调用获取相同的数据。
调用相对简单,使用Basic Authorization,只需要将API密钥作为用户名传递,并使用动态组件:从早期代码传递的csv_key变量。
我成功地发出了请求(状态代码200),但是Python的响应与Postman中的不同,除了前两个键-值对之外,它丢失了所有的键-值对:ID和描述。
我从 Postman 那里得到了这样的回应:response from postman
{
"id": "63c9c0927885bf003ecd3a1b",
"description": "Streaming analytics",
"download_url": "https://storage.googleapis.com/***-static/***.csv?GoogleAccessId=888211540537-r3m40kms2upicdr07e5rl2q67feg9loh%40developer.gserviceaccount.com&Expires=4070908800&Signature=WvuuKdddCFKjSNpst5n8yKFNR5qtC1m1o1mQZFWLHmKomJtc7npa6PbwfRoTj9FhIIqbta98VPOYKMGW89XaqXtITh15V%2Bf9opAD3BnuLjTzWC6X24RC5kMCZATXpp9DWi1Our061%2FdKlpUozi1ir7b8AwBWWf%2Bs8u5J6VoelvtEyiZIO4l%2FQdeJ26GqDLRgWElEMAlBE3TJo7m3UuE8gOQPsYBCwBSfLI1bTIytNOHZMUlWuVtMQxEHzUOujAp%2Fgqn1Q8TGGzy5GoeEmzw%2FD80xs%2BALjhT%2BxdiN9riG6%2BEcObrhPoudxl32jUhVH0EmGJwjgiJFQpz%2FLfKr86LrCQ%3D%3D",
"error": "Cannot read property 'email' of undefined",
"completed_at": "2023-01-19T22:13:39.219Z"
}
但我只使用同一API调用的Python脚本获得了前两个键值对:
response from Python
csv key: 63c9c0927885bf003ecd3a1b
api url: https://api.eventive.org/temporary_exports/63c9c0927885bf003ecd3a1b
<Response [200]>
response:[{'id': '63c9c0927885bf003ecd3a1b', 'description': 'Streaming analytics'}]
Process finished with exit code 0
我的Python脚本代码是:
import requests
import json
url_for_key = 'https://api.***.org/reports/streams?event_bucket=63279b48d8f8f1009209694f&start=1674111600000&end=1674198000000&tz=America%2FDenver'
api_key = '*************************'
header = {'content-type': 'application/json'}
r1 = requests.get(url=url_for_key, auth=(api_key, ''))
csv_obj = [r1.json()]
csv_key = csv_obj[0]['temporary_export']
#print(csv_obj)
print(f'csv key: {csv_key}')
url_for_link = 'https://api.***.org/temporary_exports/{}'.format(csv_key)
print(f'api url: {url_for_link}')
r2 = requests.get(url=url_for_link, headers=header, auth=(api_key, ''))
print(r2)
print(f'response:{[r2.json()]}')
csv_key和id是一样的。有人能帮我弄明白发生了什么吗?
非常感谢,
1条答案
按热度按时间u3r8eeie1#
我想我迟到了.但这也许能回答你的问题:
要解决这个问题,可以尝试使用Python中的csv模块直接读取CSV响应,或者使用第三方库(如panda)将CSV响应读入数据框。
这将把来自API的CSV响应读入字典列表,其中每个字典代表CSV响应中的一行,然后可以访问每个字典中的键和值以获取所需的数据。
下面是使用csv模块的示例:
在您的代码中,您使用括号
[r1.json()]
和[r2.json()]
将来自r1.json()
和r2.json()
的响应对象 Package 在一个列表中,这是不必要的,这将导致响应被打印为字典列表,即使列表中只有一个字典。在更新后的代码中,我直接访问r2.json()返回的字典,其中应该包括API返回的所有键-值对。
此外,在代码中,您不会检查响应状态代码以查看请求是否成功。您应始终检查状态代码以确保请求成功,然后再尝试分析响应。
它还使用csv模块来解析CSV响应,这是比试图将其解析为JSON更合适的方法。