首页 > 解决方案 > 具有多个条件的 Google Script 条件格式

问题描述

我正在编写一个脚本来有条件地格式化我的电子表格,但我不知道如何创建多个条件。我尝试了几次编辑来解决我的问题,即当我运行这个函数时,列中的每个空白单元格都会变成红色,或者每个满足公式2条件的单元格都会变成红色。我只希望同时满足公式 2 条件且为空白的单元格变为红色。

当我使用符号 .whenCellEmpty().whenFormulaSatisfied(formula2)... 所有符合 formula2 条件的单元格都会变成红色,即使它们不是空白的。

当我使用符号 .whenFormulaSatisfied(formula2).whenCellEmpty()... 时,所有空白单元格都会变成红色,即使它们不符合 formula2 条件。

有没有办法将这两个条件写入同一个规则?

var range2a = sheet.getRange(3, 16, sheet.getLastRow()-2, 1);
var range2b = sheet.getRange(3, 17, sheet.getLastRow()-2, 1);
var formula2 = '=OR(D3:D="Sale Escrow", D3:D="Sold", D3:D="Subsequent 
       Issue")';
var rule2a = SpreadsheetApp.newConditionalFormatRule()
    .whenCellEmpty().whenFormulaSatisfied(formula2)
    .setBackground("#FF0000")
    .setRanges([range2a])
    .build();
var rules2a = sheet.getConditionalFormatRules();
rules2a.push(rule2a);
sheet.setConditionalFormatRules(rules2a);


var rule2b = SpreadsheetApp.newConditionalFormatRule()
    .whenCellEmpty()
    .setBackground("#FF0000")
    .setRanges([range2b])
    .build();
var rules2b = sheet.getConditionalFormatRules();
rules2b.push(rule2b);
sheet.setConditionalFormatRules(rules2b); 

标签: google-apps-scriptgoogle-sheetsgs-conditional-formatting

解决方案


它在 Apps 脚本文档中没有明确说明ConditionalFormatRuleBuilder,但这些when____方法用作一次性快捷方式,通过BooleanCondition为它创建一个来定义规则何时激活。

但是,BooleanCondition文档中指出了限制:

每个条件格式规则可能包含一个布尔条件。布尔条件本身包含一个布尔条件(带有值)和格式设置。标准根据单元格的内容进行评估,结果为 atruefalse值。如果条件的计算结果为true,则条件的格式设置将应用于单元格。

因此,各种when____方法不与其他when___方法结合使用:规则中最后使用的方法是对该规则有效的方法,因为它已经替换了该规则使用的先前标准。

请注意,这BooleanCondition是 Apps Script 中的只读类 - 程序员没有可用的方法来手动构造或修改BooleanCondition. 如果可以创建或修改 a BooleanCondition,理论上可以创建可评估的布尔条件,该条件根据多个标准评估单元格。

然而,目前,最接近的方法是使用该whenFormulaSatisfied方法,因为您的公式可以根据您的需要复杂,并且执行与手动编辑BooleanCondition.

=OR(D1="A", D1="B", D1="C")*NOT(A1="")

乘法运算符等效于 Boolean AND,而加法运算符等效于 Boolean OR


推荐阅读