我有一个将查询转换为包含字典列表的字典的函数。有没有一种简单的方法可以将其中一个密钥对数据类型更改为字符串?
我的功能:
def logs(query):
client = gcb.Client()
query_job = client.query(query)
CSV_COLUMNS ='end_time,device,device_os,device_os_version,latency,megacycles,cost,device_brand,device_family,browser_version,app,ua_parse,key'.split(',')
ret = {'instances': []}
for rows in query_job.result():
var = list(rows)
l1 = dict(zip(CSV_COLUMNS,var))
ret['instances'].append(l1)
return ret
然后生成这本词典:
{'instances': [{'app': u'565',
'browser_version': u'11.0',
'cost': u'1.3075e-08',
'device': u'0',
'device_brand': u'0',
'device_family': u'Other',
'device_os': u'Windows 7',
'device_os_version': u'0',
'end_time': u'2018-04-17',
'key': 1,
'latency': 0.189589,
'megacycles': 112.0,
'ua_parse': u'0'},
{'app': u'565',
'browser_version': u'65.0.3325',
'cost': u'1.3075e-08',
'device': u'0',
'device_brand': u'0',
'device_family': u'Other',
'device_os': u'Windows 10',
'device_os_version': u'0',
'end_time': u'2018-04-16',
'key': 2,
'latency': 0.131523,
'megacycles': 190.0,
'ua_parse': u'0'}]}
我需要将'key'
密钥对设为字符串。因此key':2
需要'key':'2'
我试过这个,但它只是制作了所有数据类型字符串"
def logs(query):
client = gcb.Client()
query_job = client.query(query)
CSV_COLUMNS ='end_time,device,device_os,device_os_version,latency,megacycles,cost,device_brand,device_family,browser_version,app,ua_parse,key'.split(',')
ret = {'instances': []}
for rows in query_job.result():
var = list(rows)
l1 = dict(zip(CSV_COLUMNS,var))
l1.update({str(k):str(v) for k,v in l1.items()})
ret['instances'].append(l1)
return ret
答案 0 :(得分:1)
如果是所需的值,您可以检查密钥。代码的小改进就足够了:
l1.update({str(k): str(v) if k == 'key' else v for k, v in l1.items()})