我试图编写一个google应用程序脚本,该脚本获取每张幻灯片的幻灯片标题(就像它们在主幻灯片中一样)并将它们放在幻灯片2上格式良好的目录中。
不一定必须使用应用程序脚本,但这是我能想到的最佳方式。
function readPageElementIds(presentationId, pageId) {
var response = Slides.Presentations.get(
presentationId);
Logger.log(response.slides)
for (var i = 0; i < response.slides.length; i++) {
var slide = response.slides[i].pageElements;
for (var j = 0; j < slide.length; j++) {
if (slide[j].shape) {
var texts = slide[j].shape.text.textElements;
for (var k = 0; k < texts.length; k++) {
if (texts[k].autoText) {
Logger.log(texts[k].autoText.content);
}
}
}
}
}
}
是的,很多for循环,我不知道如何做到这一点。
答案 0 :(得分:1)
那是相当接近的。你遗失的东西:
您正在迭代所有形状,而不仅仅是标题。为此,请在shape.placeholder.type
属性上进行过滤。您只想查看包含TITLE
和CENTERED_TITLE
占位符类型的形状。
autoText
文本元素相对较少。您的大多数文字都在TextRun
文字元素
此代码可以使用:
function readPageElementIds(presentationId, pageId) {
var response = Slides.Presentations.get(
presentationId);
Logger.log(response.slides)
for (var i = 0; i < response.slides.length; i++) {
var slide = response.slides[i].pageElements;
for (var j = 0; j < slide.length; j++) {
if (slide[j].shape && slide[j].shape.placeholder
&& (slide[j].shape.placeholder.type == 'TITLE'
|| slide[j].shape.placeholder.type == 'CENTERED_TITLE')) {
var texts = slide[j].shape.text.textElements;
var shapeText = "";
for (var k = 0; k < texts.length; k++) {
if (texts[k].autoText) {
shapeText += texts[k].autoText.content;
}
if (texts[k].textRun) {
shapeText += texts[k].textRun.content;
}
}
Logger.log(shapeText);
}
}
}
}