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)
| 归档时间: |
|
| 查看次数: |
1359 次 |
| 最近记录: |