我有一个基于JavaScript的Google Apps脚本,它会遍历云端硬盘中的所有文件并将MS文件转换为Google格式。我正在使用Drive API进行上传和转换。一切似乎工作正常,除非我在Drive子文件夹中有一个文件。当文件上传回驱动器时,我无法定义父文件夹,因此它直接转到根目录。
我有父文件夹ID的句柄,但是当我向JSON字符串添加“parents:folderID”时,我看不到上传路径的任何变化。
这是我的上传和转换功能,有没有办法修改这个来定义父文件夹?我完全迷失了API ......有人可以帮忙吗?
var uploadFile = JSON.parse(
UrlFetchApp.fetch("https://www.googleapis.com/upload/drive/v2/files?uploadType=media&convert=true",
{
method: "POST",
contentType: officeFile.getMimeType(),
payload: officeFile.getBlob().getBytes(),
parents: ['id' : folderID], <<<<<<<<<<<<<<<<< this line
headers: {
"Authorization" : "Bearer " + ScriptApp.getOAuthToken()
},
muteHttpExceptions: true
}).getContentText());
答案 0 :(得分:7)
使用API的V3,parent参数的格式已经改变(似乎没有在文档中列出,这总是让事情变得有趣)。父母不再被添加为{id:}对象。
var folderId = '0BwwA4oUTeiV1TGRPeTVjaWRDY1E';
var fileMetadata = {
'name': 'photo.jpg',
'parents': [ folderId ]
};
var media = {
mimeType: 'image/jpeg',
body: fs.createReadStream('files/photo.jpg')
};
drive.files.create({
resource: fileMetadata,
media: media,
fields: 'id'
}, function(err, file) {
if(err) {
// Handle error
console.log(err);
} else {
console.log('File Id: ', file.id);
}
});
答案 1 :(得分:0)
我使用带有curl的v2 API,并通过编写以下格式的元json文件成功地将文件上传到了父文件夹中。
{
"title": "35_20190702.csv",
"mimeType": "text/csv",
"description": "Uploaded From Curl",
"parents": [
{
"kind": "drive#parentReference",
"id": ${FOLDER_ID}
}
]
}