我可以使用以下方法创建文件夹:
from Google import Create_Service
CLIENT_SECRET_FILE = "credentials_gsuite.json"
API_NAME = "drive"
API_VERSION ="v3"
SCOPES = ["https://www.googleapis.com/auth/drive"]
service = Create_Service(CLIENT_SECRET_FILE, API_NAME, API_VERSION, SCOPES)
folder_name = "Folder"
file_metadata = {"name" : folder_name, "mimeType" : "application/vnd.google-apps.folder"}
service.files().create(body=file_metadata,).execute()
而且我需要使文件夹“对网络公开”。为此,我需要指定permisions:
'role': 'reader
并输入以下内容:
'type': 'anyone'
并允许:
"allowFileDiscovery": True
根据文档判断,这应该可行:
from Google import Create_Service
CLIENT_SECRET_FILE = "credentials_gsuite.json"
API_NAME = "drive"
API_VERSION ="v3"
SCOPES = ["https://www.googleapis.com/auth/drive"]
service = Create_Service(CLIENT_SECRET_FILE, API_NAME, API_VERSION, SCOPES)
folder_name = "Folder"
file_metadata = {"name" : folder_name, "mimeType" : "application/vnd.google-apps.folder", 'role': 'reader', 'type': 'anyone',"allowFileDiscovery": True}
service.files().create(body=file_metadata,).execute()
但是我没有把它发布到网络上。我想念什么?
文档:https : //developers.google.com/drive/api/v3/reference/permissions
service.files().create()
,似乎permissions
不可写。当{"mimeType":"application/vnd.google-apps.folder","name":"sample","permissions":[{"role":"reader","type":"anyone","allowFileDiscovery":true}]}
用作“文件:创建”的请求正文时,The resource body includes fields which are not directly writable.
会发生类似错误。因此,在这种情况下,需要在创建新文件夹后使用“权限:创建”方法。当这反映到您的脚本时,它如下所示。
folder_name = "Folder"
file_metadata = {"name": folder_name, "mimeType": "application/vnd.google-apps.folder"}
folder = service.files().create(body=file_metadata,).execute()
folderId = folder.get('id')
permission = {
'role': 'reader',
'type': 'anyone',
'allowFileDiscovery': True
}
res = service.permissions().create(fileId=folderId, body=permission).execute()
print(res)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句