简体   繁体   English

用于将G Suite中具有相同名称的PDF文件合并的脚本设置为每周触发

[英]Script to merge PDF files with same name in G Suite set to weekly trigger

Looking for help compiling a code to merge PDF files with the same name in Google Documents. 寻找帮助来编译代码以合并在Google文档中具有相同名称的PDF文件。 I have a script that saves a spreadsheet as a PDF with a name which is a formatted date. 我有一个脚本,可以将电子表格另存为PDF,其名称为格式化日期。 That said, there could be up to 7 with the same name. 也就是说,最多可以有7个同名。 I need to merge these into 1 PDF but I need to do it automatically set up on a weekly trigger. 我需要将它们合并为1个PDF,但是我需要在每周触发时自动进行设置。

Anything helps. 任何帮助。 Thank you! 谢谢!

This combines the text of all PDF's in a folder 这会将所有PDF的文本合并到一个文件夹中

function combinePDFs() {
  var folder=DriveApp.getFolderById('1Zd_ty0O1WljjADzGQGrtUM57hvE5berT');
  var destFolder=DriveApp.getFolderById('1mHRFCwzqccJn83N7THnvZ8_Z-DCLeGOV');
  var files=folder.getFilesByType(MimeType.PDF);
  var text='';
  while(files.hasNext()) {
    var file=files.next();
    var blob=file.getBlob();
    var resource={title:blob.getName(),mimeType:blob.getContentType()}
    var f=Drive.Files.insert(resource, blob, {ocr: true,ocrLanguage: "en"});
    var doc=DocumentApp.openById(f.id);
    text+=doc.getBody().getText() + '\n------------------------------------------------------------\n';
    DriveApp.getFileById(f.id).setTrashed(true);//trash intermediate files
  }
  var tf=DocumentApp.create('combined.doc');
  tf.getBody().setText(text);
  tf.saveAndClose();//combined text file
  var docblob=DocumentApp.openById(tf.getId()).getAs('application/pdf');
  docblob.setName('combined.pdf');//
  destFolder.createFile(docblob);//combined PDF
  DriveApp.getFileById(tf.getId()).setTrashed(true);//trashed combined text file
}

Reference from Amit Agarwal 阿米特·阿加瓦尔(Amit Agarwal)的参考

Drive.Files.insert Drive.Files.insert

Setup a Time Based Trigger 设置基于时间的触发器

Upload files with Google Apps Script 使用Google Apps脚本上传文件

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM