TypeError: строковые индексы должны быть целыми числами при использовании Gerrit rest API для извлечения данных в pyspark - PullRequest
0 голосов
/ 04 сентября 2018

Я получаю ошибку, упомянутую выше, когда пытаюсь получить данные через API Gerrit Rest. Код выглядит следующим образом:

from requests.auth import HTTPBasicAuth 
from pygerrit2.rest import GerritRestAPI 
import os 
auth = HTTPBasicAuth('user', 'pass') headers={'Content-Type': 'application/json; charset=UTF-8'} 
rest = GerritRestAPI(url='testgerriturl.com', auth = auth) 
changes = rest.get("changes/?q=all&o=DETAILED_ACCOUNTS&n=5", headers={'Content-Type': 'application/json'}) 
data={'status':[]}

for change in changes:
       for d in change:
            data['status'].append(d[u'status'])

JSON, который я использую, имеет тип:

{u 'status': u 'MERGED', u 'topic': u 'master_e', u 'updated': u '2018-09-04 05: 40: 19.000000000', вы 'вставок': 549, вы 'созданы': u '2017-08-31 08: 03: 05.000000000', u 'change_id': u 'I7ed2f8da71e38f4908acf92f36dd', u 'hashtags': [], u 'delete': 178, вы «отправлены»: вы «2018-09-04 05: 39: 48.000000000», вы «отправлены»: False, u 'project': u 'testdemo', u 'branch': u 'master', u 'owner': { u 'username': u 'usertest', u 'email': u 'user@abc.com', u 'name': u 'userdemo', u '_account_id': 36710}, u '_number': 71090131, u 'id': u 'fm ~ master ~ I7ed71f4908acf92f36ddac3ff85b271e', u 'subject': u '% TBC FC: OSS_FC_0 App_NBI: данные веб-службы RESTful Поддержка API-PM: добавьте сценарии IUM '}

Я хочу вывод в виде:

{'status': ['MERGED'], 'deletions': [178], 'updated': ['2018-09-03 20:58:26.000000000'], 'insertions': [664], 'created': [2018-08-28 08:16:56.000000000']}

Я тут что-то не так делаю, может кто-нибудь поправит меня, что здесь нужно сделать? Спасибо

1 Ответ

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

Это должно помочь.

changes = { u'status': u'MERGED', u'topic': u'master_e', u'updated': u'2018-09-04 05:40:19.000000000', u'insertions': 549, u'created': u'2017-08-31 08:03:05.000000000', u'change_id': u'I7ed2f8da71e38f4908acf92f36dd', u'hashtags': [], u'deletions': 178, u'submitted': u'2018-09-04 05:39:48.000000000', u'submittable': False, u'project': u'testdemo', u'branch': u'master', u'owner': { u'username': u'usertest', u'email': u'user@abc.com', u'name': u'userdemo', u'_account_id': 36710 }, u'_number': 71090131, u'id': u'fm~master~I7ed71f4908acf92f36ddac3ff85b271e', u'subject': u'%TBC FC: OSS_FC_0 App_NBI: RESTful Web Service Data Access API- PM Support : add IUM scripts' }
data={'status':[], 'deletions':[], 'updated':[], 'insertions':[], 'created':[], }

for k, v in data.items():
    if k in changes:
        data[k].append(changes[k])
print(data)

Выход:

{'status': [u'MERGED'], 'deletions': [178], 'updated': [u'2018-09-04 05:40:19.000000000'], 'insertions': [549], 'created': [u'2017-08-31 08:03:05.000000000']}
...