在Google Apps脚本中获取幻灯片的标题

时间:2017-03-12 00:15:29

标签: javascript google-apps-script google-api google-slides-api

我试图编写一个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循环,我不知道如何做到这一点。

1 个答案:

答案 0 :(得分:1)

那是相当接近的。你遗失的东西:

  • 您正在迭代所有形状,而不仅仅是标题。为此,请在shape.placeholder.type属性上进行过滤。您只想查看包含TITLECENTERED_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);
      }
    }
  }
}