通过谷歌应用脚本将goole文档转换为pdf时,如何摆脱不需要的额外页面?



我有一个旧脚本,可以(除其他外(将谷歌文档转换为pdf。 它曾经工作正常,但现在在文件的 pdf 版本中出现了两个额外的空白页。

我刚刚发现这个问题也会影响谷歌文档中的"下载为 pdf"菜单选项。在这种情况下有许多解决方法,但我需要一个针对google-apps-script的解决方法。

在这篇文章中,类似问题的解决方案似乎涉及页面大小的微调。我尝试过这样的事情,但它并不适用。 我还尝试了页面大小和边距的其他(随机(变体,但无济于事。

下面我粘贴一个最小的工作示例。它应该在您的主驱动器文件夹中创建一个文档文件"test"及其pdf版本"test.pdf"。

非常感谢任何帮助摆脱两个额外的页面。

谢谢

function myFunction() {
// this function 
// - creates a google document "test", 
// - writes "this is a test" inside it
// - saves and closes the document
// - creates a pdf version of the document, called "test.pdf"
//
// the conversion is ok, except two extra blank pages appear in the pdf version.

// create google document
var doc = DocumentApp.create('test');
var docFile = DriveApp.getFileById( doc.getId() );
// set margins (I need landscape layout)
// this is an attempt to a solution, inspired by https://stackoverflow.com/questions/18426817/extra-blank-page-when-converting-html-to-pdf
var body = doc.getBody();
body.setPageHeight(595.2).setPageWidth(841.8);   
var mrg = 40; // in points
body.setMarginTop(mrg).setMarginBottom(mrg);   
body.setMarginLeft(mrg).setMarginRight(mrg);   
// write something
body.appendParagraph('this is a test').setHeading(DocumentApp.ParagraphHeading.HEADING2).setAlignment(DocumentApp.HorizontalAlignment.CENTER);  
// save and close file
doc.saveAndClose();
// convert file to pdf
var docblob = docFile.getAs('application/pdf');
// set pdf name
docblob.setName("test.pdf");
// save pdf file
var file = DriveApp.createFile(docblob);
}

我在谷歌产品论坛上的这篇文章中找到了问题的根源和解决方案,可追溯到 8 个月前。

如果未选中视图 ->打印布局中的选项,则额外的页面将显示在 pdf 中。 我用我的账户和同事的账户做了一些进一步的测试。 结果是一致的:

  1. 如果未选中视图 ->打印布局,则文档的 PDF 版本中会出现两个额外的页面
  2. 选中视图 ->打印布局时,文档的 PDF 版本具有预期的页数。
  3. 此设置还会影响 Google Apps 脚本中的文档应用服务。也就是说:仅当选中Google文档中的"查看>打印布局"选项时,上述脚本才会生成预期的pdf版本。

我不明白这种行为如何成为"功能",所以我认为这是一个错误。顺便说一句,"打印布局"似乎对我的文档没有任何明显的影响(除了弄乱pdf版本(。我很惊讶 8 个月后该错误仍然存在。

上面的数字 3 让我感到惊讶,因为我不认为在(任何(Google 文档中手动设置的选项会影响我的脚本。 我目前正在寻找一种从脚本内部设置"打印布局"选项的方法。到目前为止,我没有运气。

最新更新