gpt4 book ai didi

python - 如何使用 GoogleDrive 的 Python 快速入门循环遍历 nextPageToken

转载 作者:太空宇宙 更新时间:2023-11-03 15:56:23 24 4
gpt4 key购买 nike

我的目标是列出每个人的 Google 云端硬盘中的所有项目和文件夹。我开始尝试确保脚本能独立运行。我已经通读了 Drive REST API文档,最终找到这段代码,也可以找到here .

from __future__ import print_function
import httplib2
import os
import sys

from apiclient import discovery
from oauth2client import client
from oauth2client import tools
from oauth2client.file import Storage

reload(sys)
sys.setdefaultencoding('utf-8')

try:
import argparse
flags = argparse.ArgumentParser(parents=[tools.argparser]).parse_args()
except ImportError:
flags = None

# If modifying these scopes, delete your previously saved credentials
# at ~/.credentials/drive-python-quickstart.json
SCOPES = 'https://www.googleapis.com/auth/drive.metadata.readonly'
CLIENT_SECRET_FILE = 'client_secret.json'
APPLICATION_NAME = 'Drive API Python Quickstart'


def get_credentials():
"""Gets valid user credentials from storage.

If nothing has been stored, or if the stored credentials are invalid,
the OAuth2 flow is completed to obtain the new credentials.

Returns:
Credentials, the obtained credential.
"""
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,
'drive-python-quickstart.json')

store = 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: # Needed only for compatibility with Python 2.6
credentials = tools.run(flow, store)
print('Storing credentials to ' + credential_path)
return credentials

def main():
"""Shows basic usage of the Google Drive API.

Creates a Google Drive API service object and outputs the names and IDs
for up to 10 files.
"""
credentials = get_credentials()
http = credentials.authorize(httplib2.Http())
service = discovery.build('drive', 'v3', http=http)

results = service.files().list(
pageSize=1000,fields="nextPageToken, files(mimeType, name)").execute()
items = results.get('files', [])
if not items:
print('No files found.')
else:
print('Files:')
for item in items:
print('{0} ({1})'.format(item['name'], item['mimeType']))

if __name__ == '__main__':
main()

我的问题在于 nextPageToken,以及如何正确使用它。最大 PageSize 为 1000,因此我必须遍历 nextPageToken,从生成的 JSON 中获取它,将其放回原始循环(第 66 行?),以获得另外 1000 个结果。我该怎么做?

最佳答案

让我们看看 File:list Method 的 google drive api 文档

在请求的字段中,您正在询问 nextPageToken,结果将包含下一页的 token (如果下一页存在)。结果将是这样的:

{
...,
"nextPageToken": "V1*3|0|XXXXXX",
"files": [
{
...
},...
]
}

您可以像这样提取 nextPageToken 值:

token = results.get('nextPageToken', None)

List 方法可以带字符串参数 pageToken :

The token for continuing a previous list request on the next page. This should be set to the value of 'nextPageToken' from the previous response.

只需在下一次请求中设置参数pageToken,即可获取下一页结果:

    results = service.files().list(
pageSize=1000,
pageToken=token,
fields="nextPageToken, files(mimeType, name)").execute()
items = results.get('files', [])

现在您可以轻松地进行循环以获取所有结果。

关于python - 如何使用 GoogleDrive 的 Python 快速入门循环遍历 nextPageToken,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42980094/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com