这是我从GCM python得到的响应代码,
{"multicast_id":6343554431392278573,"success":5,"failure":15,"canonical_ids":0,"results":[{"message_id":"0:1380910865603840%356b
9054f9fd7ecd"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":
"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"message_id":"0:1380910865592683%356b9054f9fd7ecd"},{"erro
r":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"er
ror":"NotRegistered"},{"message_id":"0:1380910865600910%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"message_id":"0:1380910865
596592%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"message_id":"0:1380910865595499%356b9054f9fd7ecd"}]}
当我得到这个响应时,我想从字典中收集所有的错误键……但它看起来是一个字符串,我将尝试使用json.dumps()转储json,然后删除斜杠,但对我不起作用,甚至连ast都不起作用。我试试这个。我错过了什么?请帮帮我。
最佳答案
由于接收到的数据是有效的Python数据,因此可以简单地使用[ast.literal_eval][1]
演示
import ast
data = '''{"multicast_id":6343554431392278573,"success":5,"failure":15,"canonical_ids":0,"results":[{"message_id":"0:1380910865603840%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":
"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"message_id":"0:1380910865592683%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"error":"NotRegistered"},{"message_id":"0:1380910865600910%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"message_id":"0:1380910865596592%356b9054f9fd7ecd"},{"error":"NotRegistered"},{"message_id":"0:1380910865595499%356b9054f9fd7ecd"}]}'''
>>> pp.pprint(ast.literal_eval(data))
{ 'canonical_ids': 0,
'failure': 15,
'multicast_id': 6343554431392278573L,
'results': [ { 'message_id': '0:1380910865603840%356b9054f9fd7ecd'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'message_id': '0:1380910865592683%356b9054f9fd7ecd'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'error': 'NotRegistered'},
{ 'message_id': '0:1380910865600910%356b9054f9fd7ecd'},
{ 'error': 'NotRegistered'},
{ 'message_id': '0:1380910865596592%356b9054f9fd7ecd'},
{ 'error': 'NotRegistered'},
{ 'message_id': '0:1380910865595499%356b9054f9fd7ecd'}],
'success': 5}
>>>
然后是排除错误
>>> pp.pprint([elem['error'] for elem in ast.literal_eval(data)['results'] if 'error' in elem])
[ 'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered',
'NotRegistered']