我有一个json数组。并且需要使用python打印唯一的id。我该怎么做?如何使用python打印完整的json数组?
这是我的JSON数组:
{
"messages":
[
{
"id": "1531cf7d9e03e527",
"threadId": "1531cf7d9e03e527"
},
{
"id": "1531cdafbcb4a0e6",
"threadId": "1531bfccfceb1ed7"
}
],
"nextPageToken": "01647645424797380808",
"resultSizeEstimate": 103
}
*编辑:*
其实我写的Python代码从Gmail的API消息。 该程序将消息的id和gmail帐户消息的线程标识作为json格式给出。我只需要消息ID而不是线程ID。
from __future__ import print_function
import httplib2
import os
from apiclient import discovery
import oauth2client
from oauth2client import client
from oauth2client import tools
import json
try:
import argparse
flags = argparse.ArgumentParser(parents=[tools.argparser]).parse_args()
except ImportError:
flags = None
SCOPES = 'https://www.googleapis.com/auth/gmail.readonly'
CLIENT_SECRET_FILE = 'client_server.json'
APPLICATION_NAME = 'Gmail API Python Quickstart'
def get_credentials():
home_dir = os.path.expanduser('~')
credential_dir = os.path.join(home_dir, '.credentials')
if not os.path.exists(credential_dir):
os.makedirs(credential_dir)
credential_path = os.path.join(credential_dir,
'gmail-python-quickstart.json')
store = oauth2client.file.Storage(credential_path)
credentials = store.get()
if not credentials or credentials.invalid:
flow = client.flow_from_clientsecrets(CLIENT_SECRET_FILE, SCOPES)
flow.user_agent = APPLICATION_NAME
if flags:
credentials = tools.run_flow(flow, store, flags)
else:
credentials = tools.run(flow, store)
print('Storing credentials to ' + credential_path)
return credentials
def main():
credentials = get_credentials()
http = credentials.authorize(httplib2.Http())
service = discovery.build('gmail', 'v1', http=http)
message = service.users().messages().get(userId='me',id='').execute()
response = service.users().messages().list(userId='me',q='').execute()
messages = []
if 'messages' in response:
messages.extend(response['messages'])
print(messages)
result = loads(messages)
ids = [message['id'] for message in result['messages']]
print (ids)
while 'nextPageToken' in response:
page_token = response['nextPageToken']
response = service.users().messages().list(userId='me', q='',pageToken=page_token).execute()
messages.extend(response['messages'])
print(message['id'])
print (message['snippet'])
if __name__ == '__main__':
main()
TypeError:期望的字符串或缓冲区..它给了我raw_decode()错误@andrey – Indhuja
看来你通过python列表而不是JSON字符串(就像你在回答中说的)。 如果是这样,只需跳过json.loads的一部分,并在列表中创建列表迭代器。 'your_parsed_json ['messages']]中的[message ['id']消息'' –