TypeError: string indices must be integers while Using Gerrit rest API for extracting data in pyspark
TypeError: string indices must be integers while Using Gerrit rest API for extracting data in pyspark
我在尝试通过 gerrit rest API 获取数据时遇到上述错误。
代码如下:
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', 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' }
我希望输出格式为:
{'status': ['MERGED'], 'deletions': [178], 'updated': ['2018-09-03 20:58:26.000000000'], 'insertions': [664], 'created': [2018-08-28 08:16:56.000000000']}
我在这里做错了,有人可以纠正我这里需要做什么吗?谢谢
这应该有所帮助。
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']}
我在尝试通过 gerrit rest API 获取数据时遇到上述错误。 代码如下:
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', 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' }
我希望输出格式为:
{'status': ['MERGED'], 'deletions': [178], 'updated': ['2018-09-03 20:58:26.000000000'], 'insertions': [664], 'created': [2018-08-28 08:16:56.000000000']}
我在这里做错了,有人可以纠正我这里需要做什么吗?谢谢
这应该有所帮助。
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']}