Implement a folder move function in Google Dirve

后端 未结 1 1085
庸人自扰
庸人自扰 2021-01-17 07:09

I am very new to writing any types of scripts and am trying to write a Google Apps Script to search through folders for a particular string, and if found move the folder to

相关标签:
1条回答
  • 2021-01-17 07:53

    First, let's clear up some confusion. Two Drive-related "Services" are provided for use within Google Apps Script, Drive Services, and Docslist Services. The documentation you've referenced is for the Google Drive SDK, which is not the same thing. If you're programming in Google Apps Script, ignore the SDK documentation.

    Next, let's talk about what a folder or file is on Drive, and how that affects the concepts of "copy", "move" and "delete". A file or folder may have a folder as a parent. In fact, it may have multiple parents. If we want to have the same file or folder "copied" to another folder, we just add it as a child to the target folder. At this point, it may look like we have two items with the same ID - but what we actually have is one item with two parents. If we then remove the file or folder from the original folder (disown it, in a way), it will be left with one parent, and this will appear like a "move". The file or folder will not have been "deleted". On the other hand, if instead of removing the parent / child relationship, we DO delete the file or folder, it will appear that we have "deleted both folders", as you have described.

    So, your "move" script needs to add a new parent / child relationship, and remove the other.

    The Drive starter script that is presented when you open a new script in the editor contains a function called moveFileToFolder().

    Screenshot

    This function does what you are looking for, except that the thing it's moving is a file. However, the methods that are used for a file have cousins for folders, so you can just do some replacement to end up with moveFolderToFolder():

    /**
     * This script moves a specific folder into a given folder, and removes the folder
     * from all other folders that previously contained it. For more information on
     * interacting with files, see
     * https://developers.google.com/apps-script/drive/file
     */
    function moveFolderToFolder(sourceFolderId, targetFolderId) {
      var targetFolder = DriveApp.getFolderById(targetFolderId);
      var sourceFolder = DriveApp.getFolderById(sourceFolderId);
      var currentFolders = sourceFolder.getParents();
      while (currentFolders.hasNext()) {
        var currentFolder = currentFolders.next();
        currentFolder.removeFolder(sourceFolder);
      }
      targetFolder.addFolder(sourceFolder);
    };
    

    If you want to deal with folder Names, then you need to use getFoldersByName() to collect all matching folders, then iterate using next() into the list. Here's how that function could be modified to use folder names. To simplify things, it assumes that there is just ONE folder with the given name, and throws an exception if that's not the case. Once we have a handle on the folders we're interested in, the balance of the function remains the same as the previous example.

    function moveNamedFolderToFolder(sourceFolderName, targetFolderName) {
      var matchedFolders = DriveApp.getFoldersByName(sourceFolderName);
      if (matchedFolders.hasNext()) {
        var sourceFolder = matchedFolders.next();
        if (matchedFolders.hasNext()) throw new Error( "Source Folder Name not unique" );
      }
      matchedFolders= DriveApp.getFoldersByName(targetFolderName);
      if (matchedFolders.hasNext()) {
        var targetFolder = matchedFolders.next();
        if (matchedFolders.hasNext()) throw new Error( "Target Folder Name not unique" );
      }
    
      var currentFolders = sourceFolder.getParents();
      while (currentFolders.hasNext()) {
        var currentFolder = currentFolders.next();
        currentFolder.removeFolder(sourceFolder);
      }
      targetFolder.addFolder(sourceFolder);
    };
    
    0 讨论(0)
提交回复
热议问题