Python 谷歌表单+;GoogleCredentials=";验证范围不足”;
我正在创建一个需要阅读大量电子表格的服务器应用程序。因此,我们使用的是Python 谷歌表单+;GoogleCredentials=";验证范围不足”;,python,google-sheets-api,Python,Google Sheets Api,我正在创建一个需要阅读大量电子表格的服务器应用程序。因此,我们使用的是GoogleCredentials.get\u application\u default()fromoauth2client.client,因为服务器可以访问服务帐户。对于本地开发,我想使用我的个人凭证,所以我使用的是谷歌云SDK。我使用了gcloud auth应用程序默认登录名,以确保它正常工作 因此,创建服务非常简单: from oauth2client.client import GoogleCredentials f
GoogleCredentials.get\u application\u default()
fromoauth2client.client
,因为服务器可以访问服务帐户。对于本地开发,我想使用我的个人凭证,所以我使用的是谷歌云SDK。我使用了gcloud auth应用程序默认登录名
,以确保它正常工作
因此,创建服务非常简单:
from oauth2client.client import GoogleCredentials
from googleapiclient.discovery import build
credentials = GoogleCredentials.get_application_default()
service = build('sheets', 'v4', credentials=credentials)
事实上,到目前为止,对于一系列谷歌云产品来说,这一切都很好。
但是,当使用Sheets API时,我在执行任何请求时会出现以下错误:
googleapiclient.errors.HttpError:
<HttpError 403 when requesting https://sheets.googleapis.com/v4/spreadsheets/...
returned "Request had insufficient authentication scopes.">
但是,这似乎没有任何效果,因为create\u scoped
方法只返回self()
GOOGLE\u APPLICATION\u CREDENTIALS
设置为指向它。这也可以很好地工作,可能是因为它使用了ServiceAccountCredentials
,它实际上实现了create\u scoped
方法尝试使用
apiclient.discovery
而不是googleapiclient.discovery
。当我将太多的参数传递给build()
时,我也遇到了同样的问题,但一旦我删除了那些多余的参数,它就起作用了,我的代码与你的代码的唯一区别就是我从哪个模块中提取发现
。引用似乎不再存在于链接文档中
credentials = GoogleCredentials.get_application_default()
scoped_creds = credentials.create_scoped(SCOPES)