繁体   English   中英

如何使用 Python 和 Drive API v3 从 Google Drive 下载文件

[英]How to download a file from Google Drive using Python and the Drive API v3

我曾尝试使用 python 脚本将文件从 Google Drive 下载到我的本地系统,但在运行 Python 脚本时面临“禁止”问题。 脚本如下:

import requests

url = "https://www.googleapis.com/drive/v3/files/1wPxpQwvEEOu9whmVVJA9PzGPM2XvZvhj?alt=media&export=download"

querystring = {"alt":"media","export":"download"}

headers = {
    'Authorization': "Bearer TOKEN",

    'Host': "www.googleapis.com",
    'Accept-Encoding': "gzip, deflate",
    'Connection': "keep-alive",
    }

response = requests.request("GET", url, headers=headers, params=querystring)

print(response.url)
#
import wget
import os
from os.path import expanduser


myhome = expanduser("/home/sunarcgautam/Music")
### set working dir
os.chdir(myhome)

url = "https://www.googleapis.com/drive/v3/files/1wPxpQwvEEOu9whmVVJA9PzGPM2XvZvhj?alt=media&export=download"
print('downloading ...')
wget.download(response.url)

在这个脚本中,我遇到了禁止问题。 我在脚本中做错了什么吗?

我还尝试了在 Google Developer 页面上找到的另一个脚本,如下所示:

import auth
import httplib2
SCOPES = "https://www.googleapis.com/auth/drive.scripts"
CLIENT_SECRET_FILE = "client_secret.json"
APPLICATION_NAME = "test_Download"
authInst = auth.auth(SCOPES, CLIENT_SECRET_FILE, APPLICATION_NAME)
credentials = authInst.getCredentials()
http = credentials.authorize(httplib2.Http())
drive_serivce = discovery.build('drive', 'v3', http=http)

file_id = '1Af6vN0uXj8_qgqac6f23QSAiKYCTu9cA'
request = drive_serivce.files().export_media(fileId=file_id,
                                             mimeType='application/pdf')
fh = io.BytesIO()
downloader = MediaIoBaseDownload(fh, request)
done = False
while done is False:
    status, done = downloader.next_chunk()
    print ("Download %d%%." % int(status.progress() * 100))

这个脚本给了我一个URL mismatch error

那么应该为 Google 控制台凭据中的重定向 URL 提供什么? 或该问题的任何其他解决方案? 我是否必须在这两个脚本中从 Google 授权我的 Google 控制台应用程序? 如果是这样,授权应用程序的过程将是什么,因为我还没有找到任何关于它的文件。

要向 Google API 发出请求,工作流程本质上如下:

  1. 转到开发人员控制台,如果还没有,请登录。
  2. 创建一个云平台项目。
  3. 为您的项目启用您有兴趣与项目应用程序一起使用的 API(例如:Google Drive API)。
  4. 创建并下载OAuth 2.0 客户端 ID凭据,这将使您的应用获得使用已启用 API 的授权。
  5. 转到OAuth 同意屏幕,单击在此处输入图片说明 并使用添加您的范围在此处输入图片说明 按钮。 (范围: https : //www.googleapis.com/auth/drive.readonly适合您)。 根据您的需要选择内部/外部,现在忽略警告(如果有)。
  6. 为了获取用于发出 API 请求的有效令牌,应用程序将通过 OAuth 流程来接收授权令牌。 (因为它需要同意)
  7. 在 OAuth 流程中,用户将被重定向到您的 OAuth 同意屏幕,在该屏幕上将要求用户批准或拒绝对您应用的请求范围的访问。
  8. 如果获得同意,您的应用将收到授权令牌。
  9. 将请求中的令牌传递给您的授权 API 端点。 [ 2 ]
  10. 构建驱动服务以发出 API 请求(您将需要有效的令牌) [ 1 ]

笔记:

Drive API v3 的 Files 资源的可用方法在这里

使用 Python Google APIs Client 时,您可以根据 Google APIs Client for Python 文档使用export_media()get_media()


重要的:

此外,请检查您使用的范围,实际上允许您做您想做的事情(从用户的驱动器下载文件)并相应地设置它。 ATM 您的目标范围不正确。 请参阅OAuth 2.0 API 范围


示例代码参考:

  1. 构建驱动服务:
import google_auth_oauthlib.flow
from google.auth.transport.requests import Request
from google_auth_oauthlib.flow import InstalledAppFlow
from googleapiclient.discovery import build
 
 
class Auth:
 
    def __init__(self, client_secret_filename, scopes):
        self.client_secret = client_secret_filename
        self.scopes = scopes
        self.flow = google_auth_oauthlib.flow.Flow.from_client_secrets_file(self.client_secret, self.scopes)
        self.flow.redirect_uri = 'http://localhost:8080/'
        self.creds = None
 
    def get_credentials(self):
        flow = InstalledAppFlow.from_client_secrets_file(self.client_secret, self.scopes)
        self.creds = flow.run_local_server(port=8080)
        return self.creds

 
# The scope you app will use. 
# (NEEDS to be among the enabled in your OAuth consent screen)
SCOPES = "https://www.googleapis.com/auth/drive.readonly"
CLIENT_SECRET_FILE = "credentials.json"
 
credentials = Auth(client_secret_filename=CLIENT_SECRET_FILE, scopes=SCOPES).get_credentials()
 
drive_service = build('drive', 'v3', credentials=credentials)
  1. 发出导出或获取文件的请求
request = drive_service.files().export(fileId=file_id, mimeType='application/pdf')

fh = io.BytesIO()
downloader = MediaIoBaseDownload(fh, request)
done = False
while done is False:
    status, done = downloader.next_chunk()
    print("Download %d%%" % int(status.progress() * 100))

# The file has been downloaded into RAM, now save it in a file
fh.seek(0)
with open('your_filename.pdf', 'wb') as f:
    shutil.copyfileobj(fh, f, length=131072)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM