使用Apps脚本在Google文档中编号表行

时间:2016-01-08 20:27:37

标签: javascript google-apps-script

我正在处理一个脚本,该脚本接收文本并将每个段落放在一个带编号的表格单元格中。我遇到了一个问题,其中每个换行符被脚本计为段落,这意味着我的表格中有空单元格或编号不正确。

这是工作脚本(减去行号):

function formatArticle() {
  var doc = DocumentApp.getActiveDocument()
  var body = doc.getBody(); 

  // Get the paragraphs
  var paras = body.getParagraphs();

  // Add a table to fill in with copied content
  var addTable = body.appendTable();
  for (var i=0;i<paras.length;++i) {

    // If the paragraph is text, add a table row and insert the content.
    if(i % 2 == 0) {
      var tr = addTable.appendTableRow();
      var text = paras[i].getText();

      // Number the table rows as they're added in a cell to the left.
      for(var j=0;j<2;j++) {
        if(j == 0) {
          var td = tr.appendTableCell(i);
          } else {
            var td = tr.appendTableCell(text);
          }
        }
      }

    // Shrink left column.
    addTable.setColumnWidth(0, 65);

    // Delete the original text from the document.
    paras[i].removeFromParent();
  }
}

Here's a demo Google Doc 所以,如果有帮助的话,你可以看到自己如何在不自行设置新文本的情况下进行格式化。

2 个答案:

答案 0 :(得分:0)

试试这个:tr.appendTableCell(i/2 +1)

// Number the table rows as they're added in a cell to the left.
  for(var j=0;j<2;j++) {
    if(j == 0) {
      var td = tr.appendTableCell(i/2 +1);
      } else {
        var td = tr.appendTableCell(text);
      }
    }
  }

答案 1 :(得分:0)

<强>逻辑

您应该做的是迭代每个段落并检查该段落是否包含文本。如果是,则添加一行并将文本放入其中,否则跳过该段并跳转到下一段。

<强>实施

function formatArticle(){ 
    var doc = DocumentApp.getActiveDocument()
    var body = doc.getBody(); 

    // Get the paragraphs
    var paras = body.getParagraphs();
    var addTable = body.appendTable();

    //paragraph index 
    var pIndex = 0;
    for(var i = 0 ; i < paras.length ; i++){
        var para = paras[i];
        var paraStr = para.editAsText().getText();
        // if there is string content in paragraph
        if(paraStr.length){
            var tr = addTable.appendTableRow();
            var td1 = tr.appendTableCell(pIndex);
            var td2 = tr.appendTableCell(paraStr);
            pIndex ++;
        }
        para.removeFromParent();
    }
    // Shrink left column.
    addTable.setColumnWidth(0, 65);
}

这里您从段落var paraStr = para.editAsText().getText();获取字符串并检查内容是否存在if(paraStr.length)如果是,则创建一行,在其中插入段落索引和段落文本。