3

背景

我有一个 Google Apps 脚本,我们用它来解析脚注内容,用双括号括起来,代替脚注编号上标。预期的结果应该是:

脚本之前

这是我的足球指数。1


1这是我的足球内容,带有链接重点

脚本之后

这是我的足球指数。(((这是我的足球内容,带有 链接重点。)

问题

一切正常,除了当我解析双括号中的脚注时,它们丢失了所有链接和格式:

这是我的足球指数。(((这是我的足球内容,带有链接和重点。)

如果有人可以帮助我修复下面的代码,我将非常感谢您的帮助:)

解决方案:

function convertFootNotes () {
  var doc = DocumentApp.getActiveDocument()
  var copy = generateCopy(doc) // make a copy to avoid damaging the original
  var openCopy = doc; //DocumentApp.openById(copy.getId()) // you have to use the App API to copy, but the Doc API to manipulate
  performConversion(openCopy); // perform formatting on the copy
}

function performConversion (docu) {
  var footnotes = docu.getFootnotes(); // get the footnotes
  footnotes.forEach(function (note) {
    // Traverse the child elements to get to the `Text` object
    // and make a deep copy

    var paragraph = note.getParent(); // get the paragraph
    var noteIndex = paragraph.getChildIndex(note); // get the footnote's "child index"
    insertFootnote(note.getFootnoteContents(),true, paragraph, noteIndex);
    note.removeFromParent();
  })
} 

function insertFootnote(note, recurse, paragraph, noteIndex){
  var numC = note.getNumChildren(); //find the # of children
  paragraph.insertText(noteIndex," ((");
  noteIndex++;
  for (var i=0; i<numC; i++){
    var C = note.getChild(i).getChild(0).copy();

    if (i==0){
      var temp = C.getText();
      var char1 = temp[0];
      var char2 = temp[1];
      if (C.getText()[0]==" "){
        C = C.deleteText(0,0);
      }
    }

    if (i>0){
      paragraph.insertText(noteIndex,"\n");
      noteIndex++;
    }
    paragraph.insertText(noteIndex,C);
    noteIndex++;

  } //end of looping through children
  paragraph.insertText(noteIndex,"))");
}

function generateCopy (doc) {
  var name = doc.getName() + ' #PARSED_COPY' // rename copy for easy visibility in Drive
  var id = doc.getId()
  return DriveApp.getFileById(id).makeCopy(name)
}
4

1 回答 1

1

除了添加的代码之外,是否对代码进行了任何更改以))使其无法正常工作?删除((&))在测试时仍然没有应用格式;getText()以 a 形式返回元素内容String,而不是包含格式信息的富文本对象/元素。

要到达Text对象:

  1. getFootnoteContents().getChild(0)返回脚注部分 Paragraph
  2. getChild(0).getChild(0)返回该Text段落的对象
  3. copy()返回要使用的文本对象的分离深层副本

注意:FootnoteSection如果在或它的子元素中有其他子元素Paragraph,您将需要添加某种类型/索引检查以获取正确的元素。然而,有了基本的脚注——如上面的例子——这是正确的路径。

function performConversion (docu) {
  var footnotes = docu.getFootnotes() // get the footnotes
  var noteText = footnotes.map(function (note) {
    // Traverse the child elements to get to the `Text` object
    // and make a deep copy
    var note_text_obj = note.getFootnoteContents().getChild(0).getChild(0).copy();

    // Add the `((` & `))` to the start and end of the text object
    note_text_obj.insertText(0, " ((");
    note_text_obj.appendText(")) ");

    return note_text_obj // reformat text with parens and save in array
  })

  ...

}
于 2017-11-23T02:06:50.117 回答