我正在尝试操作Google幻灯片中的表格,但是似乎有记录在案的操作会在AppScript中引发错误。
https://developers.google.com/apps-script/reference/slides/table
注释掉的行会引发以下错误:
不支持更新此页面元素类型的大小。
var table = (slides[page])
.insertTable(rows, columns)
.setTop (0)
.setLeft(0)
//.setWidth(presentation.getPageWidth());
//.setHeight(presentation.getPageHeight());
答案 0 :(得分:1)
这个答案怎么样?我也已与您确认相同的情况。我认为这可能是一个错误。因为当使用Slides API时,可以创建调整宽度和高度的表。因此,在当前变通方法中,当创建表时需要调整表的大小时,我使用Slides API创建表。示例脚本如下。
要使用示例脚本,请在运行脚本之前先按以下步骤在高级Google服务和API控制台上启用Slides API。
使用Slides API修改脚本后,脚本将如下所示。
var presentation = SlidesApp.getActivePresentation();
var slides = presentation.getSlides();
var resource = {"requests":[{"createTable": {
"rows": 2,
"columns": 3,
"elementProperties": {
"size": {
"width": {"unit": "PT", "magnitude": presentation.getPageWidth()},
"height": {"unit": "PT", "magnitude": presentation.getPageHeight()},
},
"pageObjectId": slides[0].getObjectId()},
}
}]};
Slides.Presentations.batchUpdate(resource, presentation.getId());
如果要修改现有表的大小,可以使用以下脚本。
var presentation = SlidesApp.getActivePresentation();
var slides = presentation.getSlides();
var table = slides[0].getTables()[0];
var tableObjectId = table.getObjectId();
var resource = {"requests": [
{"updateTableColumnProperties": {
"objectId": tableObjectId,
"tableColumnProperties": {"columnWidth": {"unit": "PT", "magnitude": presentation.getPageWidth() / table.getNumColumns()}}, "fields": "*"}
},
{"updateTableRowProperties": {
"objectId": tableObjectId,
"tableRowProperties": {"minRowHeight":{"unit": "PT", "magnitude": presentation.getPageHeight() / table.getNumRows()}},"fields":"*"}
}
]};
Slides.Presentations.batchUpdate(resource, presentation.getId());
如果这不是您想要的解决方法,我深表歉意。