检查文件夹中的文件名,如果找不到则导出为 PDF

Checking a folder for a filename, and exporting as PDF if it is not found

我对脚本编写还很陌生,现在已经尝试了很多小时,所以我希望你能帮助我。

我有一个 dash 文件夹,其中包含 Google 个名为 "X" 的工作表,我有一个 pdf 文件夹,其中包含名为 "X.pdf" 的 pdf。我试图遍历我的 dashfiles +“.pdf”的名称以找到丢失的文件,最后在同一个文件夹中创建它的 pdf。但是,我的脚本循环次数过多。如果 pdf 文件夹中已存在名称为 +".pdf" 的文件,我希望它跳过破折号文件。这是我的代码

function createPdf() {
  var pdfFolder = DriveApp.getFolderById("ID")
  var pdfFiles = pdfFolder.getFiles();
  var dashFolder = DriveApp.getFolderById('ID');
  var dashFiles = dashFolder.getFiles();
  var pdfNames = [];
  var dashNames = [];

  while (pdfFiles.hasNext()) {
     var currentFile2 = pdfFiles.next();
     var fileName2 = currentFile2.getName();
     pdfNames.push(fileName2);
  }

  while (dashFiles.hasNext()) {
    var currentFile = dashFiles.next();
    var fileName = currentFile.getName();
    dashNames.push(fileName);

    for (p in pdfNames) {
      if((fileName + ".pdf") == pdfNames[p]) {
        Logger.log("YES");
      }
      else {
        var xlsBlob = currentFile.getBlob(); // Blob source of Excel file for conversion
        var xlsFilename = currentFile.getName(); // File name to give to converted file; defaults to same as source file
        pdfFolder.createFile(currentFile.getAs(MimeType.PDF));
        Logger.log("pdf Created");
      }
    }
  }
}

我真正的问题在于我将有 100 多张纸需要转换为 pdf,这将超过 6 分钟的限制。因此,我正在尝试构建一个可以自行触发并从中断处继续的脚本,跳过 pdf 文件夹中已有的工作表并创建缺少的工作表。

我在这里可能有点不知所措,所以我希望有人能给我一些提示:-)

您可以创建一个值为true的文件名对象,然后检查对象中是否存在该文件名。如果文件名存在,则继续循环

var pdfNames = {};//Create an object - not an array
pdfNames[fileName2] = true;//Put the file name into the object
if (pdfNames[fileName]) {//Test for file name in the object

代码:

function createPdf() {
  var currentFile,fileName,xlsBlob,xlsFilename;
  var pdfFolder = DriveApp.getFolderById("ID")
  var pdfFiles = pdfFolder.getFiles();
  var dashFolder = DriveApp.getFolderById('ID');
  var dashFiles = dashFolder.getFiles();
  var pdfNames = {};
  var dashNames = [];

  while (pdfFiles.hasNext()) {
     var currentFile2 = pdfFiles.next();
     var fileName2 = currentFile2.getName();
     pdfNames[fileName2] = true;//Put the file name into the object
  }

  while (dashFiles.hasNext()) {
    currentFile = dashFiles.next();
    fileName = currentFile.getName();
    dashNames.push(fileName);

    if (pdfNames[fileName]) {//The file name was found in the object of pdf files
      Logger.log("YES");
      continue;
    }

    xlsBlob = currentFile.getBlob(); // Blob source of Excel file for conversion
    xlsFilename = currentFile.getName(); // File name to give to converted file; defaults to same as source file
    pdfFolder.createFile(currentFile.getAs(MimeType.PDF));
    Logger.log("pdf Created");
  }

}

原答案:

以不同的方式测试pdf数组中文件名是否存在。

pdfNames.indexOf(fileName + ".pdf") !== -1

如果在数组中找不到值,则 indexOf() returns 减一。 因此,如果 return 值不减一,则找到文件名。如果找到文件名,您不想创建新文件,所以继续。

function createPdf() {
  var currentFile,fileName,xlsBlob,xlsFilename;
  var pdfFolder = DriveApp.getFolderById("ID")
  var pdfFiles = pdfFolder.getFiles();
  var dashFolder = DriveApp.getFolderById('ID');
  var dashFiles = dashFolder.getFiles();
  var pdfNames = [];
  var dashNames = [];

  while (pdfFiles.hasNext()) {
     var currentFile2 = pdfFiles.next();
     var fileName2 = currentFile2.getName();
     pdfNames.push(fileName2);
  }

  while (dashFiles.hasNext()) {
    currentFile = dashFiles.next();
    fileName = currentFile.getName();
    dashNames.push(fileName);

    if (pdfNames.indexOf(fileName + ".pdf") !== -1) {//The file name was found in the array of pdf files
      Logger.log("YES");
      continue;
    }

    xlsBlob = currentFile.getBlob(); // Blob source of Excel file for conversion
    xlsFilename = currentFile.getName(); // File name to give to converted file; defaults to same as source file
    pdfFolder.createFile(currentFile.getAs(MimeType.PDF));
    Logger.log("pdf Created");
  }

}

你错误地使用了循环。目前您创建了更多相同 sheet 的 pdf,因为当您遍历 dashFiles 时,您为每个存在的 PDF 创建了一个 pdf。

像这样更改部分代码:

var pdfNames = {}; //Object instead of array

while (pdfFiles.hasNext()) {
   var currentFile2 = pdfFiles.next();
   var fileName2 = currentFile2.getName();
   pdfNames[fileName2] = true; // use PDF name as key for faster searching
}

while (dashFiles.hasNext()) {
  var currentFile = dashFiles.next();
  var fileName = currentFile.getName();

  if(pdfNames[fileName + ".pdf"]) { // is exists pdf?
    Logger.log("YES");
  }
  else {
    var xlsBlob = currentFile.getBlob(); // Blob source of Excel file for conversion
    var xlsFilename = currentFile.getName(); // File name to give to converted file; defaults to same as source file
    pdfFolder.createFile(currentFile.getAs(MimeType.PDF));
    Logger.log("pdf Created");
  }
}