我对这个平台很陌生。
我试图制作一个 Google Apps 脚本来从我的 Google 文件夹中获取文件详细信息。我再次从 Stack Overflow 中找到了脚本。
它工作得很好,直到现在运行似乎出现错误。我无法诊断出同样的情况。
我现在已经创建了完全相同文件的副本。
在文件中有一个名为“脚本日志”的工作表,其中记录了数据。
该脚本被命名为“驱动器文件”。函数“listAll”将在其中运行。
运行时,我检查记录器并找到“异常:错误值”
要提取的文件的细节有点保密,这就是我没有分享的原因。
请帮助我更正代码。该文件在此链接中。
https://docs.google.com/spreadsheets/d/1ktUe3qyf-TJp4K_FC8ELzLgh5q7jNRCP8YJF-z2li4A/edit?usp=sharing 下面是用于它的代码。
/**
* Google Apps Script - List all files & folders in a Google Drive folder,
& write into a speadsheet.
* - Main function 1: List all folders
* - Main function 2: List all files & folders
*
* Hint: Set your folder ID first! You may copy the folder ID from the
browser's address field.
* The folder ID is everything after the 'folders/' portion of the
URL.
*
* @version 1.0
* @see https://github.com/mesgarpour
*/
// TODO: Set folder ID
var folderId = '0B_BwvZZtlhP4OFNTeUhLX2NCWk0';
// Main function 1: List all folders, & write into the current sheet.
function listFolers(){
getFolderTree(folderId, false);
};
// Main function 2: List all files & folders, & write into the current
sheet.
function listAll(){
getFolderTree(folderId, true);
};
// =================
// Get Folder Tree
function getFolderTree(folderId, listAll) {
try {
// Get folder by id
var parentFolder = DriveApp.getFolderById(folderId);
// Initialise the sheet
var file, data, sheet = SpreadsheetApp.openById("d/1qP7AoydxJs7IkiURkLKkOzUSxTd1Ha8jLmETBq54zgI").getSheetByName("Script Logs")
sheet.clear();
sheet.appendRow(["Full Path", "Name", "Date", "URL", "Last Updated",
"Description", "Size"]);
// Get files and folders
getChildFolders(parentFolder.getName(), parentFolder, data, sheet,
listAll);
} catch (e) {
Logger.log(e.toString());
}
};
// Get the list of files and folders and their metadata in recursive mode
function getChildFolders(parentName, parent, data, sheet, listAll) {
var childFolders = parent.getFolders();
// List folders inside the folder
while (childFolders.hasNext()) {
var childFolder = childFolders.next();
// Logger.log("Folder Name: " + childFolder.getName());
data = [
parentName + "/" + childFolder.getName(),
childFolder.getName(),
childFolder.getDateCreated(),
childFolder.getUrl(),
childFolder.getLastUpdated(),
childFolder.getDescription(),
childFolder.getSize() / 1024,
];
// Write
sheet.appendRow(data);
// List files inside the folder
var files = childFolder.getFiles();
while (listAll & files.hasNext()) {
var childFile = files.next();
// Logger.log("File Name: " + childFile.getName());
data = [
parentName + "/" + childFolder.getName() + "/" + childFile.getName(),
childFile.getName(),
childFile.getDateCreated(),
childFile.getUrl(),
childFile.getLastUpdated(),
childFile.getDescription(),
childFile.getSize() / 1024,
];
// Write
sheet.appendRow(data);
}
// Recursive call of the subfolder
getChildFolders(parentName + "/" + childFolder.getName(), childFolder,
data, sheet, listAll);
}
};
提前致谢。