2

我有一个 Google Apps 脚本,它通过调用 body.replaceText('TextA', 'TextB'); 将模板文档副本中的占位符替换为一些文本。

现在我想扩展它以包含图像。有谁知道如何做到这一点?

谢谢你,安德烈

编辑:只是为了弄清楚我的脚本是做什么的。我在电子表格中创建了一个 Google 表单。我创建了一个脚本,它在表单提交时运行,遍历与表单对应的工作表,查找未处理的行,从相应的单元格中获取值并将它们放入 Google 文档的副本中。Google 表单中的某些字段是多行文本字段,这就是 '\r\r' 的来源。

这是我现在想出的一种解决方法,并不优雅,但它到目前为止有效:

// replace <IMG src="URL"> with the image fetched from URL
function processIMG_(Doc) {

  var totalElements = Doc.getNumChildren();

  for( var j = 0; j < totalElements; ++j ) {

    var element = Doc.getChild(j);
    var type = element.getType();

    if (type =='PARAGRAPH'){
      var par_text = element.getText();

      var start = par_text.search(new RegExp('<IMG'));
      var end = par_text.search(new RegExp('>'));
      if (start==-1)
        continue;

      // Retrieve an image from the web.
      var url = getURL_(par_text.substring(start,end));
      if(url==null)
        continue;

      // Before image
      var substr = par_text.substring(0,start);
      var new_par = Doc.insertParagraph(++j, substr);

      // Insert image
      var resp = UrlFetchApp.fetch(url);
      new_par.appendInlineImage(resp.getBlob());

      // After image
      var substr = par_text.substring(end+1);
      Doc.insertParagraph(++j, substr);

      element.removeFromParent();
      j -= 2; // one - for latter increment; another one - for increment in for-loop
      totalElements = Doc.getNumChildren();      
    }      
  }
}
4

1 回答 1

5

这是一段(大致)你想要的代码。

(可能还有其他方法可以做到这一点,它肯定需要一些改进,但总体思路就在那里)

我选择在文档中使用“###”来标记图片将被插入的位置,图片必须在您的谷歌驱动器中(或者更准确地说是在“某些”谷歌驱动器中)。下面的代码使用了一个文档我分享了一个图片,我也分享了,所以你可以试试。这里是文档的链接,不要忘记删除图片并在测试前在某处放置###(如果有人在你之前运行过代码;-)

function analyze() { // just a name, I used it to analyse docs
  var Doc = DocumentApp.openById('1INkRIviwdjMC-PVT9io5LpiiLW8VwwIfgbq2E4xvKEo');
  var image = DocsList.getFileById('0B3qSFd3iikE3cF8tSTI4bWxFMGM')
    var totalElements = Doc.getNumChildren();
    var el=[]
    for( var j = 0; j < totalElements; ++j ) {
      var element = Doc.getChild(j);
      var type = element.getType();
Logger.log(j+" : "+type);// to see doc's content
       if (type =='PARAGRAPH'){
       el[j]=element.getText()
       if(el[j]=='###'){element.removeFromParent();// remove the ###
         Doc.insertImage(j, image);// 'image' is the image file as blob 
         }
       }
    }
}

编辑:要使此脚本正常工作,### 字符串必须在其段落中单独存在,之前或之后都没有其他字符...请记住,每次使用 ENTER 强制换行时,文档都会创建一个新段落。

于 2012-06-26T16:56:12.127 回答