从Google文档到电子表格格式化的Google脚本副本文本保持粗体/下划线...格式

时间:2018-06-29 07:24:26

标签: google-apps-script google-sheets google-docs google-spreadsheet-api google-docs-api

我有一个内部带有文本的Google文档,并且执行了脚本,因此如果选择该文本,它将被复制到单元格中的Google Spreadsheet。我到达时要复制文本,但我不知道该怎么做保持相同的样式颜色,问题是我不知道如何设置粗体/斜体。

这是我到目前为止所做的:

var SPREADSHEET_ID = "....."; // = assign your spreadsheet id to this variable
var SHEET_NAME = "Feuille 1"; // = assign your sheet name to this variable
var COORD_LIGNE = 5 ;
var COORD_COLONNE = 4 ;

function onOpen(e) {
  DocumentApp.getUi()
  .createMenu('Test')
  .addItem('Copier la selection du texte', 'Copy')
  .addToUi();
}

function Copy() {
  var ss = DocumentApp.getActiveDocument();
  var selection = ss.getSelection();
  var result = "";
  var fontColor, background , font,  fontWeight ,TextAlignment  ;
  
  var ok_underline, ok_italis , ok_bold, ok_strikethrough ;
  //Proceed only if something is selected, otherwise selection will be null >>>> pour voir le style/font/couleur on test pour 1 seul élément
  if (selection) {
    
    var elements = selection.getRangeElements();
    for (var i = 0; i < elements.length; i++) {
      var element = elements[i];
      
      // Only modify elements that can be edited as text; skip images and other non-text elements. ??? on n'a pas fait les cas italique et bold etc. ici >>>>>  element.getElement().asText().setUnderline(underline)
      // Qui sont des méthodes booleans >>>>>>>>>>>>>>>>>>>>>>>>>   isUnderline(offset)       isItalic()        isBold()   isStrikethrough()   ???? TextAlignment ne marche pas ???
      if (element.getElement().editAsText) {
        result += element.getElement().asText().getText();
        // get formatting
        fontColor = element.getElement().asText().getForegroundColor();
        background = element.getElement().asText().getBackgroundColor();
        font = element.getElement().asText() .getFontFamily();
        fontWeight = element.getElement().asText().getFontSize();
        TextAlignment = element.getElement().asText().getTextAlignment();
        
        if(element.getElement().asText().isUnderline() )
          ok_underline = 1;
        
        if(element.getElement().asText().isItalic() )
          ok_italis = 1;
        
        if(element.getElement().asText().isBold() )
          ok_bold = 1;
        
        if(element.getElement().asText().isStrikethrough() )
          ok_strikethrough = 1;
      }
    }
    
    var tss = SpreadsheetApp.openById(SPREADSHEET_ID);
    var ts = tss.getSheetByName(SHEET_NAME);
    
    var trange = ts.getRange(COORD_LIGNE, COORD_COLONNE); //la première cellule A1 première ligne + première colonne 
    trange.setBackground(background).setFontColor(fontColor).setFontFamily(font).setFontSize(fontWeight).setValue(result);
    /** on va bien encadrer la valeur dans la cellule >>>> on va redimensioner la colonne **/
    /**  vérification pour mettre text underline / italic / bold / strikethrough   **/
    if ( ok_underline ) 
    if ( ok_italis ) 
    if ( ok_bold ) 
    if ( ok_strikethrough ) 
/**  i don't know how to set it in fonction of the ok variable  **/
    ts.autoResizeColumn(COORD_COLONNE); 
  }
}

Exported text from Google Doc to a cell in Google Spreadsheet 任何想法都很棒!非常感谢。

编辑:非常感谢Signo,这非常有用,这是我到目前为止编辑的代码:

        if(element.getElement().asText().isUnderline() )
          ok_underline = 1;
         Logger.log("Value of ok_underline is  " + ok_underline);
        if(element.getElement().asText().isItalic() )
          ok_italis = 1;
        
        if(element.getElement().asText().isBold() )
          ok_bold = 1;
        
        if(element.getElement().asText().isStrikethrough() )
          ok_strikethrough = 1;
      }
    }
    
    var tss = SpreadsheetApp.openById(SPREADSHEET_ID);
    var ts = tss.getSheetByName(SHEET_NAME);
    
    var trange = ts.getRange(COORD_LIGNE, COORD_COLONNE); //la première cellule A1 première ligne + première colonne 
    trange.setBackground(background).setFontColor(fontColor).setFontFamily(font).setFontSize(fontWeight).setValue(result);
    /** on va bien encadrer la valeur dans la cellule >>>> on va redimensioner la colonne **/
    /**  vérification pour mettre text underline / italic / bold / strikethrough   **/
    if ( ok_underline ) {
      trange.setFontLine("underline");
       Logger.log("Call setFontLine() method ");
    }

这是我的结果。取消划定不起作用哪里会有问题? The undeline doesn't work where would be the problem?

1 个答案:

答案 0 :(得分:1)

此解决方案应适合您的情况:

if ( ok_underline ) 
    trange.setFontLine("underline");
if ( ok_italis ) 
    range.setFontStyle("italic");
if ( ok_bold ) 
    trange.setFontWeight("bold");
if ( ok_strikethrough )
    trange.setFontLine("line-through");
if ( if_underline && ok_strikethrough ) // Check if both styles are active
    trange.setFontLine("underline|line-through"); // This is not documented but should do the trick, set both styles at the same time to avoid reset