Python не может отправить запрос GET через запросы - PullRequest
0 голосов
/ 07 сентября 2018

Так что я давно не кодировал. Недавно вернулся к этому и вот что я пытаюсь сделать. Я извлекаю VINS из таблицы Google, а затем использую библиотеку запросов, чтобы отправить запрос GET на URL, который затем декодирует этот VIN и возвращает данные (https://vpic.nhtsa.dot.gov/api/).

Вот что я сделал до сих пор, я могу получить VIN из электронной таблицы и отобразить его, но когда я пытаюсь отправить запрос GET, Python возвращает множество ошибок для меня. Это первый раз, когда я написал код на Python, и мне потребовалось некоторое время, чтобы получить код там, где он сейчас.

def main():
store = file.Storage('token.json')
creds = store.get()
if not creds or creds.invalid:
    flow = client.flow_from_clientsecrets('credentials.json', SCOPES)
    creds = tools.run_flow(flow, store)
service = build('sheets', 'v4', http=creds.authorize(Http()))

# Call the Sheets API
SPREADSHEET_ID = 'The Sheets ID that I use'
RANGE_NAME = 'A:A'
result = service.spreadsheets().values().get(spreadsheetId=SPREADSHEET_ID,
                                            range=RANGE_NAME).execute()
values = result.get('values', [])

if not values:
    print('No data found.')
else:

    for row in values:
        # Print columns A, which correspond to indices 0.
        print('%s' % (row[0]))
        URL = "https://vpic.nhtsa.dot.gov/api/vehicles/DecodeVin/"
        VIN=row[0]
        PARAMS={VIN}
        r=requests.get(url=URL, params=PARAMS)
        data=r.json
        r.status_code
        text=r.text
        print(text)

if __name__ == '__main__':
    main()

Я получаю следующие ошибки: я получаю VIN (не упоминая здесь):

 Traceback (most recent call last):
  File "quickstart.py", line 47, in <module>
    main()
  File "quickstart.py", line 40, in main
    r=requests.get(url=URL, params=PARAMS)
  File "/Library/Python/2.7/site-packages/requests/api.py", line 72, in get
    return request('get', url, params=params, **kwargs)
  File "/Library/Python/2.7/site-packages/requests/api.py", line 58, in request
    return session.request(method=method, url=url, **kwargs)
  File "/Library/Python/2.7/site-packages/requests/sessions.py", line 498, in request
    prep = self.prepare_request(req)
  File "/Library/Python/2.7/site-packages/requests/sessions.py", line 441, in prepare_request
    hooks=merge_hooks(request.hooks, self.hooks),
  File "/Library/Python/2.7/site-packages/requests/models.py", line 309, in prepare
    self.prepare_url(url, params)
  File "/Library/Python/2.7/site-packages/requests/models.py", line 427, in prepare_url
    enc_params = self._encode_params(params)
  File "/Library/Python/2.7/site-packages/requests/models.py", line 97, in _encode_params
    for k, vs in to_key_val_list(data):
ValueError: too many values to unpack

Как я могу определить, в чем может быть проблема? Я программирую после очень долгого времени и совершенно нового для Python.

1 Ответ

0 голосов
/ 07 сентября 2018

Смотря на их документацию, вы хотите

VIN=row[0]
r=requests.get(url=URL + VIN, params={'format': 'json'})

вместо

...