python - 使用 python api 在谷歌驱动器中显示子文件夹
问题描述
我正在尝试列出谷歌驱动器中的所有文件夹(和子文件夹)。
我的根文件夹中有六个子文件夹。但我的代码只显示文件。
def credentials_from_file():
"""Load credentials from a service account file
Args:
None
Returns: service account credential object
https://developers.google.com/identity/protocols/OAuth2ServiceAccount
"""
# https://developers.google.com/identity/protocols/googlescopes#drivev3
SCOPES = [
'https://www.googleapis.com/auth/drive'
]
SERVICE_ACCOUNT_FILE = './auth_creds.json'
credentials = service_account.Credentials.from_service_account_file(
SERVICE_ACCOUNT_FILE, scopes=SCOPES)
return credentials
credentials = credentials_from_file()
service = discovery.build('drive', 'v3', credentials=credentials)
results = service.files().list(pageSize=10, fields="nextPageToken, files(id, name)").execute()
items = results.get('files', [])
if not items:
print('No files found.')
else:
print('Files:')
for item in items:
print(u'{0} ({1})'.format(item['name'], item['id']))
我如何让它也告诉我子文件夹?谢谢!
更新#1。这是 OAuth 版本。它允许浏览器创建一个令牌,然后应该运行,但是在创建令牌之后,它会在执行时冻结:
from httplib2 import Http
from oauth2client import file, client, tools
from getfilelistpy import getfilelist
SCOPES = 'https://www.googleapis.com/auth/drive.metadata.readonly'
store = file.Storage('token.json')
creds = store.get()
if not creds or creds.invalid:
flow = client.flow_from_clientsecrets('rrc_crds.json', SCOPES)
creds = tools.run_flow(flow, store)
resource = {
"oauth2": creds.authorize(Http()),
"fields": "files(name,id)",
}
res = getfilelist.GetFileList(resource) # or r = getfilelist.GetFolderTree(resource)
print(res)
解决方案
我想提出以下修改。
修改点:
- 在您的脚本中,您使用的是服务帐户。从您的评论中,我可以理解您想在自己的 Google 云端硬盘中检索文件。所以我建议在这种情况下使用 OAuth2,因为 Drive of Service Account 与您使用 Google 帐户登录的 Drive 不同。
- 关于脚本,为了检索特定文件夹下的所有文件和文件夹,我为此发布了一个库。所以在这里,我想提出它。
- 该库是https://github.com/tanaikech/getfilelistpy。该库使用 Drive API v3 中的 list 方法。
- 您可以通过
$ pip install getfilelistpy
.
示例脚本:
使用 OAuth2 的示例脚本如下。在这个示例脚本中,OAuth2 的过程使用了 Google 的 quickstart。请在运行脚本之前检查这一点。
from httplib2 import Http
from oauth2client import file, client, tools
from getfilelistpy import getfilelist
SCOPES = 'https://www.googleapis.com/auth/drive.metadata.readonly'
store = file.Storage('token.json')
creds = store.get()
if not creds or creds.invalid:
flow = client.flow_from_clientsecrets('client_secret.json', SCOPES)
creds = tools.run_flow(flow, store)
resource = {
"oauth2": creds.authorize(Http()),
"id": "### Folder ID ###",
"fields": "files(name,id)",
}
res = getfilelist.GetFileList(resource) # or r = getfilelist.GetFolderTree(resource)
print(res)
- 如果您不使用
"id": "### Folder ID ###"
,则会检索自己的 Google Drive 中的所有文件。所以当你的驱动器中有很多文件时,它会花费很长时间。因此,首先请使用文件和文件夹数量较少的文件夹的特定文件夹ID作为测试运行。
参考:
推荐阅读
- python - 如何修复“TypeError:+ 的不支持的操作数类型:'int' 和 'NoneType'”
- reactjs - 创建反应应用程序:配置笑话:运行所有测试文件
- javascript - 如何在jQuery中添加悬停文本?
- java - 哈希映射允许空插入但哈希表不允许空插入?
- java - 如何从 Coldfusion 2016 中加载 jsoup Java 库?
- makefile - makefile 可以在不先构建所有内容的情况下说“构建目标 X 和依赖它的所有内容”吗?
- java - 我将如何在我的代码中使用 SwitchMap (RXJAVA)?
- powerbi - 通过电子邮件向内部团队(分发组)发送 Power BI 报告
- sql - 在返回多列的一列上选择不同的
- cloud - 如何计算云计费?