从postman与python API调用获得不同的响应

ig9co6j1  于 2023-03-18  发布在  Postman
关注(0)|答案(1)|浏览(348)

我尝试使用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是一样的。有人能帮我弄明白发生了什么吗?
非常感谢,

u3r8eeie

u3r8eeie1#

我想我迟到了.但这也许能回答你的问题:
要解决这个问题,可以尝试使用Python中的csv模块直接读取CSV响应,或者使用第三方库(如panda)将CSV响应读入数据框。
这将把来自API的CSV响应读入字典列表,其中每个字典代表CSV响应中的一行,然后可以访问每个字典中的键和值以获取所需的数据。
下面是使用csv模块的示例:

import requests
import csv

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['temporary_export']
print(f'csv key: {csv_key}')

url_for_link = f'https://api.***.org/temporary_exports/{csv_key}'
print(f'api url: {url_for_link}')

r2 = requests.get(url=url_for_link, headers=header, auth=(api_key, ''))

# Read the CSV response using the csv module
reader = csv.DictReader(r2.iter_lines(decode_unicode=True))
response = [row for row in reader]

print(response)

在您的代码中,您使用括号[r1.json()][r2.json()]将来自r1.json()r2.json()的响应对象 Package 在一个列表中,这是不必要的,这将导致响应被打印为字典列表,即使列表中只有一个字典。
在更新后的代码中,我直接访问r2.json()返回的字典,其中应该包括API返回的所有键-值对。
此外,在代码中,您不会检查响应状态代码以查看请求是否成功。您应始终检查状态代码以确保请求成功,然后再尝试分析响应。
它还使用csv模块来解析CSV响应,这是比试图将其解析为JSON更合适的方法。

相关问题