Google скрипт со списком папок, подпапок и файлов - PullRequest
0 голосов
/ 03 ноября 2019

У меня есть скрипт Google, в котором указаны имя папки, идентификатор папки, имя файла и идентификатор файла папки Google Диска, включая подпапки. Однако в первой строке мне нужен полный полный путь к файлу, а не только имя папки

, например, файл с именем abc.pdf находится в папке /documents/files/new/abc.pdf

.

Мой скрипт показывает мне имя new вместо полного пути к папке / documents / files / new /

`function listFolderContents() {

  var ss = SpreadsheetApp.getActive();
  var sheet = SpreadsheetApp.getActiveSheet();
  sheet.clearContents();
  sheet.appendRow(["Foldername","FolderID","Filename","FileID"]);

  var topFolderID = DriveApp.getFolderById('FOLDER_ID_HERE');
  var foldername = topFolderID.getName();

  var folders = DriveApp.getFoldersByName(foldername)
  var folder = folders.next();                  
  traverseFolder(folder, sheet);

  sortByFoldername();
};

function traverseFolder(folder, sheet) { 
  listFilesInFolder(folder, sheet);  
  var subFolders = folder.getFolders();
  while (subFolders.hasNext()) {
    traverseFolder(subFolders.next(), sheet);
  }
}

function listFilesInFolder(folder, sheet) {
  var folderID = folder.getId();
  var foldername = folder.getName();
  var contents = folder.getFiles();  
  while(contents.hasNext()) {
    var file = contents.next();
    var filename = file.getName();
    var fileID = file.getId();
    sheet.appendRow( [foldername,folderID,filename,fileID] );     
  } 
}

function sortByFoldername(){
  var ss = SpreadsheetApp.getActive();
  var sheet = ss.getSheetByName('Sheet1');
  var range = sheet.getRange("A2:D");
  range.sort([{column: 1, ascending: true}]);
  }`

1 Ответ

1 голос
/ 04 ноября 2019

Я наконец сделал это !!! Этот сценарий работает должным образом и создает список с именем папки, идентификатором папки, именем файла и идентификатором файла всех папок и файлов, включенных в Fiolder на Google Диске:

    var folderId = 'FOLDERIDGOESHERE'; //Replace the folder id with the folder id of the parent folder in the Google Drive, where you would like to start sorting through the drive. 


// Main function 1: List all folders, & write into the current sheet.
function listFolders(){
  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.getActiveSheet();
    sheet.clear();
    sheet.appendRow(["Full Path", "Folder ID", "FileName"]);

    // 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.getId()


    ];
    // 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(),
        childFolder.getId(),
        childFile.getName(),
        childFile.getId()

      ];
      // Write
      sheet.appendRow(data);
    }

    // Recursive call of the subfolder
    getChildFolders(parentName + "/" + childFolder.getName(), childFolder, data, sheet, listAll);  
  }
};    
...