所以,我遇到了 merge() 函数的一些问题:
我编写了一个函数来创建电子表格/工作表并排列它们,一切都很好。
但是当我想合并工作表的一些单元格时,我收到一条错误消息,说“无法合并选定的单元格”[不是实际的英文错误消息,而是等效的]。
见代码:
function style(id,magasin,Nom,dateTest){
var ssMois = SpreadsheetApp.openById(id);
var sheet = ssMois.getSheetByName(Nom);
var date=dateTest.toLocaleDateString();
sheet.getRange("A1:D1").merge();
sheet.getRange("B1").setValue("Feuille de caisse du:");
sheet.getRange("C1:E1").mergeAcross();
sheet.getRange("B1").setValue(date);
sheet.getRange("B2:F2").merge();
sheet.getRange("B2").setValue(magasin);
//BLOC RECETTE DU JOUR ******
sheet.getRange("B4:F4").merge();
sheet.getRange("B4").setValue("RECETTE DU JOUR");
sheet.getRange("C5").setValue("Caisse 1");
sheet.getRange("D5").setValue("Caisse 2");
sheet.getRange("E5").setValue("Total");
sheet.getRange("E7:E10").setFormulas("=R[0]C[-2]+R[0]C[-1]")
sheet.getRange("B6").setValue("CAISSIER");
sheet.getRange("B7").setValue("ESPECE DU JOUR");
sheet.getRange("B8").setValue("CARTE BLEU");
sheet.getRange("B9").setValue("CHEQUE");
sheet.getRange("B10").setValue("TOTAL (€)");
//BLOC FOND DE CAISSE ******
sheet.getRange("B12:F12").merge();
sheet.getRange("B12").setValue("DETERMINATION DU FOND DE CAISSE");
sheet.getRange("B13").setValue("Fond de caisse J-1");
sheet.getRange("B14").setValue("SOUS-TOTAL");
sheet.getRange("B15").setValue("PRELEVEMENT");
sheet.getRange("B16").setValue("SORTIE DE CAISSE");
sheet.getRange("B17").setValue("Fond de caisse théorique:");
sheet.getRange("B18").setValue("Fond de caisse compté:");
sheet.getRange("B19").setValue("Erreur");
//BLOC SORTIE DE CAISSE ******
}
奇怪的事实来了:
如果我将第一个合并sheet.getRange("A1:D1").merge();
放在评论中,代码就可以了。
如果我将范围“A1:D1”更改为其他任何内容,有时,代码将起作用。
如果我将完整的代码放在注释中,除了前三行,将起作用。
当然,我可以使用合并按钮手动合并它。
不明白这个错误,你可以帮我看看更正或解决方法吗?