0

所以,我遇到了 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”更改为其他任何内容,有时,代码将起作用。
如果我将完整的代码放在注释中,除了前三行,将起作用。
当然,我可以使用合并按钮手动合并它。

不明白这个错误,你可以帮我看看更正或解决方法吗?

4

1 回答 1

0

我的代码失败了:我首先合并 A1:D1,然后是 C1:E1 列。

因此,脚本无法合并 C1:E1,因为 C1 单元格已经与 A1 合并。

我唯一可以抱怨的是错误消息可以更具体:没有显示单元格或行;只是一个通用的消息“不能合并单元格”

于 2013-08-21T01:29:49.890 回答