我有一个内部带有文本的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);
}
}
编辑:非常感谢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 ");
}
答案 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