使用 Google Apps 脚本更新 Google 文档中的嵌入式图表

Gen*_*neM 5 charts google-docs google-sheets google-apps-script

TLDR;如何使用文档中的脚本编辑器更新文档中嵌入的表格图表?

我知道有一个脚本可以为 Google 幻灯片执行此操作,但我正在尝试在 Google 文档中执行此操作,但找不到任何相关文档。

https://developers.google.com/slides/how-tos/add-chart#refreshing_a_chart

具体来说,我有一个 Google Doc。该文档包含大约 30 个表格和嵌入式图表,它们都链接到单独的 Google 表格。所有 30 个都来自一个 Google Sheet。现在,每次电子表格更改时,我都可以让我们的非极客人员点击所有 30 个“更新”悬停按钮,但我希​​望电子表格会发生很大变化,我想对文档进行白痴证明以确保它始终可用-迄今为止。据我所知,这不是 Google Apps 开箱即用的功能,所以我想编写一个脚本来完成它。

但是我找不到从 Google Doc 访问 EmbeddedChart 的任何方法。

如果我可以像在 Sheets 中那样运行这样的东西,我可能会弄清楚,但我不能:

var ss = SpreadsheetApp.getActiveSpreadsheet();
    var sheet = ss.getSheets()[0];
    var charts = sheet.getCharts();
    for (var i in charts) {
       var chart = charts[i];
       // Update the chart
    }
}
Run Code Online (Sandbox Code Playgroud)

尽管 docs 具有以下功能,DocumentApp.getActiveDocument()但对象 Document 不包含功能getCharts()。我相信它们被认为是图像,但图像没有更新功能。

甚至可以使用脚本访问/更新文档中的 EmbeddedChart 吗?也许通过在编辑时通过电子表格运行脚本并从那里更新文档?您可以在所有内容的幻灯片中执行此操作似乎很奇怪,但不能在文档中执行。

小智 0

在 Google Docs DOM 图表中为 InlineImages,这里是记录图像属性的脚本。但它们看起来是只读的,并且此方法的文档以死胡同结束:“如果元素包含此属性的多个值,则为 null。” https://developers.google.com/apps-script/reference/document/inline-image#getLinkUrl()

function myFunction() {
  var doc = DocumentApp.getActiveDocument()
  var body = doc.getBody()
  var pars = body.getParagraphs()
  var atts = img.getAttributes();
  // Log the paragraph attributes.
  for (var att in atts) {
    Logger.log(att + ":" + atts[att]);
  }
  
  for (var par in pars) {
    Logger.log(pars[par].getText());
    var chN = pars[par].getNumChildren()
    Logger.log(chN);
    if(chN>0){
      var type = pars[par].getChild(0).getType()
      Logger.log(type);
      if(type=="INLINE_IMAGE"){
            
        var atts = pars[par].getChild(0).getAttributes()
        Logger.log(JSON.stringify(atts));
          for (var att in atts) {
            Logger.log(att + ":" + atts[att]);
          }
      }
    
    }
  }
  return
}
Run Code Online (Sandbox Code Playgroud)