Google Apps Script TeamDrive DriveApp.searchFolders and DriveApp.searchFiles does not return any results

瘦欲@ 提交于 2021-01-28 06:01:06

问题


I have some Google Apps script code that searchs for files and folders on TeamDrive.

The issue I am having is that if a file or folder is created by my colleague, when I run my script it can't find the file. If I create a file, and my colleague runs the script, the script can't find the file even though we both have access to view, edit and can see the files and folders in Drive. If one of us edits the file made by the other person, then it becomes visible from the search.

I ran into a similar problem with the Drive REST api when doing some android development. In Android when calling files().list(), It took my a while to find out that I had to set the following in order for my search to be successfull every single time.

  1. .setSupportsTeamDrives(true)
  2. .setIncludeTeamDriveItems(true)
  3. .setCorpora("teamDrive")
  4. .setTeamDriveId(myFolder.getTeamDriveId())

I assume I am running into the same issue with my apps script code.

//Create the N Google docs files
function CreateNFiles(){
  var spreadsheet = SpreadsheetApp.getActive();
  var Nmain = spreadsheet.getSheetByName("Nmain")
  var spreadsheetId = spreadsheet.getId();
  var pdfDir = "Form Data";
  var TemplatesFolder = null;

  //Check and see if there is a 'Form Data' folder
  var NFolderId = null;
  var RFolderId = DriveApp.getFileById(spreadsheetId).getParents().next().getId();
  var files = DriveApp.searchFolders('parents="'+RFolderId+'" and trashed=false');
  while (files.hasNext()) {
    var myfile = files.next();
    if(myfile.getName() == pdfDir){
      NOFolderId = myfile.getId();
    }
  }

https://developers.google.com/apps-script/reference/drive/drive-app#searchFiles(String)

this says to refer to

https://developers.google.com/drive/api/v3/search-parameters#examples_for_teamdriveslist

so I could potentially use

corpora="teamDrive"

is there a way to setSupportsTeamDrives? and setIncludeTeamDriveItems? and setTeamDriveId? in google apps scripts


回答1:


Finding Files and Folders in a Team Drive

Here's a couple of functions I've been working on for my own needs. They're still a work in progress but one can file folders within a team drive folder and another can find items within a team drive folder. The Logger.log is setup to display item number, title, id, and mimeType.

This one finds Items (either files or folders). You can tell them apart by their types.

function findItemsInTeamDriveFolder(teamDriveId,folderId){
  var teamDriveId=teamDriveId || '0AFN5OZjg48ZvUk9PVA';
  var folderId=folderId || '1LK76CVE71fLputdFAN-zuL-HdRFDWBGv';
  var options={
    "corpora":"teamDrive",
    "includeTeamDriveItems":true,
    "orderBy":"folder",
    "q":Utilities.formatString('\'%s\' in parents',folderId),
    "supportsTeamDrives":true,
    "teamDriveId":teamDriveId
    };
  var files=Drive.Files.list(options);
  var data=JSON.parse(files);
  for(var i=0;i<data.items.length;i++){
    Logger.log('\nItem: %s - Title: %s - Id: %s - Type:%s - Trashed: %s\n',i+1,data.items[i].title,data.items[i].id,data.items[i].mimeType,data.items[i].explicitlyTrashed?'true':'false'); 
  }
}

This one just finds folders in a folder. It's not reentrant it's a one level deal but currently that's all I need.

function findFoldersInATeamDriveFolder(teamDriveId,folderId){
  var teamDriveId=teamDriveId || '0AAc6_2qyI7C0Uk9PVA';
  var folderId=folderId || '1HenWOXTSCg96iAvA0ZkgEA9EGKlch4fz';
  var optionalArgs={
    "corpora":"teamDrive",
    "includeTeamDriveItems":true,
    "orderBy":"folder",
    "q":Utilities.formatString('\'%s\' in parents and mimeType = \'application/vnd.google-apps.folder\'',folderId),
    "supportsTeamDrives":true,
    "teamDriveId":teamDriveId
  }
  var list=Drive.Files.list(optionalArgs)
  var data=JSON.parse(list);
  for(var i=0;i<data.items.length;i++){
    Logger.log('\nItem: %s - Title: %s - Id: %s - Type: %s - Trashed;%s\n',i+1,data.items[i].title,data.items[i].id,data.items[i].mimeType,data.items[i].explicitlyTrashed?'true':'false'); 
    findItemsInTeamDriveFolder(teamDriveId,data.items[i].id)
  }
}

I thought that they might be helpful.

  • Meta Data for a file:
  • Search Parameters:
  • Drive.Files.List Documentation:



回答2:


I just used Coopers code to list files that were in a shared drive. I added the code to find the teamdriveID. Two things that cost me some time and might be helpful for others: the number of files is restricted to 100 per default. So I changed it to 200 here. Also, the options file includes trashed files (very confusing) so I filtered them out with an if statement - I am sure this can be done more elegantly but this worked :)

var resource = {
  'value': 'emailstring',
  'type': 'user',
  'role': 'writer'
}

var teamDriveId
// If you have several Team Drives, loop through and give access
  var TeamDrive = Drive.Teamdrives.list();
  for(var i = 0; i < TeamDrive.items.length; i++) {
    if(TeamDrive.items[i].name == "foldernamestring") {
      // This ID may also be a single file inside a Team Drive
      teamDriveId = TeamDrive.items[i].id;
      Logger.log("found "+TeamDrive.items[i].name);          
    }
  }

var options={
        "corpora":"teamDrive",
        "maxResults":200,
        "includeTeamDriveItems":true,
        "supportsTeamDrives":true,
        "teamDriveId":teamDriveId
        };
var files=Drive.Files.list(options);
var data=JSON.parse(files);

var nritems= data.items.length
Logger.log("nritems "+nritems);          
for(var i=0;i<nritems;i++){
        if (data.items[i].explicitlyTrashed == false){
          Logger.log('\nItem: %s - Title: %s - Id: %s - Type:%s - Trashed: %s\n',i+1,data.items[i].title,data.items[i].id,data.items[i].mimeType,data.items[i].explicitlyTrashed?'true':'false'); 
        }
      }


来源:https://stackoverflow.com/questions/53732509/google-apps-script-teamdrive-driveapp-searchfolders-and-driveapp-searchfiles-doe

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!