3

我正在尝试通过填写表格来制作自动报告。脚本从电子表格的最后一行读出数据。然后将报告制作为 Google Doc。本文档中的一些标签显示了项目应该在哪里。%meterx%是为米。

这些可以是图像或文本。对于普通段落,这适用于 type = 段落的第一个循环。但它会跳过表格。我需要%meterx%用图像替换表格单元格中的 ,就像我对段落所做的那样,但我被困在代码中以查看表格。

我看到了一些替换文本的方法,但这似乎是用图像替换它的唯一方法。

  var totalElements = doc.getNumChildren();
  var el=[]
  for( var j = 0; j < totalElements; ++j ) {
  var element = doc.getChild(j);
  var type = element.getType();

   if (type =='PARAGRAPH'){
      el[j]=element.getText()

      if(el[j]=='%meter3%'){element.removeFromParent();
      var newimage = UrlFetchApp.fetch('http://chart.googleapis.com/chart?chf=bg,s,67676700&chs=280x150&cht=gm&chds=0,10&chd=t:'+row[4]+'&chdlp=b').getBlob();   
      doc.insertImage(j, newimage); 

   if (type =='TABLE'){
      var tablerows=element.getNumRows();
      Logger.log(tablerows);
      for ( var i = 0; i < tablerows; ++i ) {
        var tablerow = element.getRow(0)
        Logger.log(tablerow);   // <--- gives TableRow
      }  /// STUCK !! :)
4

1 回答 1

3

ATableRow包含子元素,类型为TableCell,其中也包含子元素。PARAGRAPH如果它们是空白或包含文本,则它们是类型。

您可以使用TableCellwith访问文本getText(),但最好先确认单元格包含文本。

下面的代码处理PARAGRAPHTABLE元素类型,对于表格,它探索TABLECELL元素。我不知道你在用你的数组做什么el[],所以我把它省略了,还注释掉了图像替换代码——相反,我只是记录表的结构和内容以供说明。要完成您的目标,您应该使用与PARAGRAPH.

注意:我使用了一些此处未详细说明的辅助函数,它们应该是不言自明的,getFileByName_()并且elementTypeToText_().

function Q13869576() {
  var folder = "StackOverflow";
  var docname = "Q13869576.gdoc";
  var docId = getFileByName_(folder, docname).getId();

  var doc = DocumentApp.openById(docId);
  var docBody = doc.getActiveSection();

  var totalElements = doc.getNumChildren();
  var el=[]
  for( var j = 0; j < totalElements; ++j ) {
    var element = doc.getChild(j);
    var type = element.getType();

    switch (type) {
      case DocumentApp.ElementType.PARAGRAPH:
        el[j]=element.getText()

        if(el[j]=='%meter3%'){
          Logger.log( "Found tag in paragraph" );
//          element.removeFromParent();
//          var newimage = UrlFetchApp.fetch('http://chart.googleapis.com/chart?chf=bg,s,67676700&chs=280x150&cht=gm&chds=0,10&chd=t:'+row[4]+'&chdlp=b').getBlob();   
//          doc.insertImage(j, newimage);
        }
        break;

      case DocumentApp.ElementType.TABLE:
        var tablerows=element.getNumRows();
        Logger.log(tablerows);
        for ( var row = 0; row < tablerows; ++row ) {
          var tablerow = element.getRow(row)
          for ( var cell=0; cell < tablerow.getNumCells(); ++cell) {
            Logger.log( "Table Row("+row+") Cell ("+cell+")");
            Logger.log(
                  elementTypeToText_(tablerow.getChild(cell).getType())
                  +" with child type "
                  +elementTypeToText_(tablerow.getChild(cell).getChild(0).getType()));
            var celltext = tablerow.getChild(cell).getText();
            Logger.log( "Text is ("+celltext+")" );
          }
        }
        break;
    }
  }
}

这是来自示例文档的日志摘录,其中包含一个带有%meter3%标签的单元格的表格:

...
Table Row(1) Cell (2)
TABLE_CELL with child type PARAGRAPH
Text is (%meter3%)
...
于 2012-12-22T04:31:47.477 回答