删除空文件夹团队云端硬盘

问题描述 投票:0回答:4

在迁移到团队云端硬盘期间,我们有一个文件夹被迁移了两次。第一次被中断,现在我们有数千个重复的文件夹,里面什么也没有。我想删除或至少删除特定团队驱动器上完全空的任何文件夹。我发现了一个旧脚本,我尝试修改如下:

   function delEmptyFolders() {

var folders = DriveApp.getFolders();

var ss = SpreadsheetApp.create("folderslist");

while (folders.hasNext()) {

var folder = folders.next();

var files = folder.getFiles();

var childfolders = folder.getFolders();

var filecount = 0;

var foldercount = 0;

while (childfolders.hasNext()){

var childfolder = childfolders.next();

foldercount ++;

}

while (files.hasNext()){

var file = files.next();

filecount ++;

}

ss.appendRow([folder.getId(),folder.getName(),filecount, foldercount]);

if (filecount == 0 && foldercount == 0){

folder.setTrashed(true);

}

}

}

我的问题是如何让此脚本在特定团队驱动器上运行,或者更好的是在团队驱动器上的特定文件夹中运行?

评论中回答了原始问题 - 下面的新脚本 - 评论中的后续问题

提前感谢您的帮助,并表示歉意,因为我在编码或脚本方面经验不足。

 function starEmptyFolders() {

     var folders = DriveApp.getFolderById('ID').getFolders();


var ss = SpreadsheetApp.create("test");

while (folders.hasNext()) {

var folder = folders.next();

var files = folder.getFiles();

var childfolders = folder.getFolders();

var filecount = 0;

var foldercount = 0;

while (childfolders.hasNext()){

var childfolder = childfolders.next();

foldercount ++;

}

while (files.hasNext()){

var file = files.next();

filecount ++;
}

  ////////////////////
var child = childfolders;
  var subFolders = child.getFolders();
  while(subFolders.hasNext()) {
    var subFolder = subFolders.next();
    var subfoldercount = 0;
    subfoldercount ++}




  ///////////////////////////
}
  ss.appendRow([folder.getId(),folder.getName(),filecount, foldercount, subfoldercount,]);

if (filecount == 0 && foldercount == 0){

folder.setStarred(true);
google-apps-script google-drive-api google-drive-shared-drive
4个回答
1
投票

这是一个修改后的函数,它将递归删除空文件夹并将其记录到电子表格中。

function deleteEmptyFolders() {
  var parentFolder = DriveApp.getFolderById('<folder ID goes here>');
  var folders = parentFolder.getFolders();
  var ss = SpreadsheetApp.create("ScriptDeletes");
  while (folders.hasNext()) {
    var childfolder = folders.next();
    recurseFolder(parentFolder, childfolder, ss);
  }
}

function recurseFolder(parentFolder, folder, ss) {
        var filecount = 0;
        var foldercount = 0;

        var files = folder.getFiles();               // get the list of files in the root of that folder
        var childfolders = folder.getFolders();      // get the list of sub folders in the root of that folder

        while (childfolders.hasNext()) {               // count the sub folders
            var childfolder = childfolders.next();
            recurseFolder(folder, childfolder, ss);
            foldercount++;
        }

        while (files.hasNext()) {                      // count the files in the root of the folder
            var file = files.next();
            filecount++;
        }

       if (filecount == 0 && foldercount == 0) {            
            parentFolder.removeFolder(folder);
            ss.appendRow([folder.getId(),folder.getName(),filecount, foldercount]);
       }             
}

0
投票

我对@Brett的答案做了轻微修改,因为它以自上而下的顺序而不是自下而上的顺序遍历目录树。我有很多嵌套的空子目录,想将它们全部删除,所以我最好在递归之后(重新)检查文件计数/文件夹计数,以便考虑更深层次的删除。我还通过不关心文件数或文件夹数来加快速度,只要文件是否存在 另外,如果您想删除文件夹,我认为最好使用

.setTrashed

,这样它就会被丢弃,而不是

.removeFolder
,它只是将其移动到隐藏的顶级目录

function deleteEmptyFolders() { var parentFolder = DriveApp.getFolderById('FOLDER_ID'); var folders = parentFolder.getFolders(); var ss = SpreadsheetApp.openById("SPREADSHEET_ID") while (folders.hasNext()) { var childfolder = folders.next(); recurseFolder(parentFolder, childfolder, ss); } } function recurseFolder(parentFolder, folder, ss) { var childfolders = folder.getFolders(); // get the list of sub folders in the root of that folder while (childfolders.hasNext()) { // count the sub folders var childfolder = childfolders.next(); recurseFolder(folder, childfolder, ss); } var hasFile = folder.getFiles().hasNext(); // get the list of files in the root of that folder var hasFolder = folder.getFolders().hasNext(); // get the list of files in the root of that folder if (!hasFile && !hasFolder) { folder.setTrashed(true) ss.appendRow([folder.getId(),folder.getName()]); } }



0
投票

对于特定文件夹,请务必在脚本中输入正确的“FOLDER_ID” 另外,输入运行脚本的电子表格的 SPREADSHEET_ID


0
投票

function recurseFolder(myFolder) { var childfolders = myFolder.getFolders(); // get the list of sub folders in the root of that folder while (childfolders.hasNext()) { // count the sub folders recurseFolder(childfolders.next()); } var hasFile = myFolder.getFiles().hasNext(); // get the list of files in the root of that folder var hasFolder = myFolder.getFolders().hasNext(); // get the list of files in the root of that folder if (!hasFile && !hasFolder) { myFolder.setTrashed(true); } }

	
© www.soinside.com 2019 - 2024. All rights reserved.