5

我的 Google Drive 看起来像这样:

图片1.jpg

歌曲1.mp3

a/b/file1.txt

a/b/file2.txt

a/b/file3.jpg

a/b/file4.m4a

a/b/...

我想使用 PyDrive 下载文件夹“b”中的每个文件。在查看文档并检查 StackOverflow 之后,我仍然无法弄清楚如何做到这一点。如何使用 PyDrive 下载文件夹“b”(包含在文件夹“a”中)中的所有文件。此外,如果相关,请注意文件夹“b”包含数千个文件。

4

1 回答 1

11

我想到了。基本上,您需要使用文件 ID 来列出或下载文件夹的内容。

假设 file_list 是根目录:

for file1 in file_list:
    if file1['title'] == '[name_of_target_folder]':
        folder_id = file1['id']

然后

> folder_id 
> 'WIU1xyz19g83abcdefg'

(例如)

获取“文件夹”中的每个文件:

file_list = drive.ListFile({'q': "'{}' in parents and trashed=false".format(folder_id)}).GetList()

下载“文件夹”中的每个文件:

for i, file1 in enumerate(sorted(file_list, key = lambda x: x['title']), start=1):
    print('Downloading {} from GDrive ({}/{})'.format(file1['title'], i, len(file_list)))
    file1.GetContentFile(file1['title'])
于 2017-10-29T20:25:26.140 回答