将图片替换为Google文档中的表格

时间:2018-11-22 10:40:32

标签: google-apps-script google-docs google-docs-api

我要用Google文档中包含该图像的表替换选定的图像。当我运行代码时,没有表格插入到Google文档中。

    function insertImage(ID, caption) {
    var selection = DocumentApp.getActiveDocument().getSelection();
    if (selection) {
        var elements = selection.getSelectedElements();
        var tImg = elements[0].getElement();
        var cells = [
            [tImg.asInlineImage(), ID+': '+caption]
        ];
        var parentElement = tImg.getParent();
        parentElement.insertTable(parentElement.getChildIndex(tImg) + 1, cells)
        tImg.removeFromParent();
    }
}

不会删除图像,也不会添加表格。谢谢!

1 个答案:

答案 0 :(得分:0)

  • 您要将选定的图像替换为表格。
  • 您要将选定的图像移到插入表的单元格的第一列。文本放在第二栏中。

如果我对您的问题的理解是正确的,那么如何修改?

修改点:

  • insertTable()的方法是类主体的方法。
  • 需要检索图像的位置作为文档正文的子索引。
  • 插入表格后,图像将插入到插入表格的单元格中。
  • 在此修改中,当删除图像时,它会删除图像的段落。这样,可以在不包括换行符的情况下将图像替换到表格中。这种情况与在单元格中插入图像相同。
  • getSelectedElements()已过时。因此,请使用getRangeElements()

当以上几点反映到脚本中时,它如下所示。

修改后的脚本:

function insertImage(ID, caption) {
//  ID = "sample ID"; // for sample
//  caption = "sample caption"; // for sample

  var doc = DocumentApp.getActiveDocument(); // Added
  var body = doc.getBody(); // Added
  var selection = doc.getSelection(); // Modified
  if (selection) {
    var elements = selection.getRangeElements(); // Modified
    var e = elements[0].getElement(); // Modified
    if (e.getType() == DocumentApp.ElementType.INLINE_IMAGE) { // Added
      var tImg = e.asInlineImage(); // Modified
      var parentElement = tImg.getParent();
      var cells = [["", ID + ': ' + caption]]; // Modified
      var table = body.insertTable(body.getChildIndex(parentElement), cells); // Modified
      var cell = table.getCell(0, 0); // Added
      cell.insertImage(0, tImg.getBlob()).getParent().asParagraph().getNextSibling().removeFromParent(); // Added
      tImg.getParent().asParagraph().removeFromParent(); // Modified
    }
  }
}
输入:

enter image description here

输出:

enter image description here

注意:

  • 在脚本中,使用了所选元素的第一个图像。所以我遵循了这一点。

参考文献:

如果这不是您想要的,请告诉我。我想修改它。