Class DataValidation

Проверка данных

Правила проверки данных доступа. Чтобы создать новое правило, используйте Spreadsheet App.newDataValidation() и Data ValidationBuilder . Вы можете использовать Range.setDataValidation(rule) чтобы установить правило проверки для диапазона.

// Log information about the data validation rule for cell A1.
const cell = SpreadsheetApp.getActive().getRange('A1');
const rule = cell.getDataValidation();
if (rule != null) {
  const criteria = rule.getCriteriaType();
  const args = rule.getCriteriaValues();
  Logger.log('The data validation rule is %s %s', criteria, args);
} else {
  Logger.log('The cell does not have a data validation rule.');
}

Методы

Метод Тип возврата Краткое описание
copy() Data ValidationBuilder Создает построитель для правила проверки данных на основе настроек этого правила.
get Allow Invalid() Boolean Возвращает true , если правило отображает предупреждение, когда входные данные не проходят проверку, или false если входные данные полностью отклоняются.
get Criteria Type() Data ValidationCriteria Получает тип критерия правила, определенный в перечислении Data ValidationCriteria .
get Criteria Values() Object[] Получает массив аргументов для критериев правила.
get Help Text() String Получает текст справки по правилу или null , если текст справки не задан.

Подробная документация

copy()

Создает построитель для правила проверки данных на основе настроек этого правила.

// Change existing data validation rules that require a date in 2013 to require
// a date in 2014.
const oldDates = [new Date('1/1/2013'), new Date('12/31/2013')];
const newDates = [new Date('1/1/2014'), new Date('12/31/2014')];
const sheet = SpreadsheetApp.getActiveSheet();
const range = sheet.getRange(1, 1, sheet.getMaxRows(), sheet.getMaxColumns());
const rules = range.getDataValidations();

for (let i = 0; i < rules.length; i++) {
  for (let j = 0; j < rules[i].length; j++) {
    const rule = rules[i][j];

    if (rule != null) {
      const criteria = rule.getCriteriaType();
      const args = rule.getCriteriaValues();

      if (criteria === SpreadsheetApp.DataValidationCriteria.DATE_BETWEEN &&
          args[0].getTime() === oldDates[0].getTime() &&
          args[1].getTime() === oldDates[1].getTime()) {
        // Create a builder from the existing rule, then change the dates.
        rules[i][j] = rule.copy().withCriteria(criteria, newDates).build();
      }
    }
  }
}
range.setDataValidations(rules);

Возвращаться

Data ValidationBuilder — конструктор на основе настроек этого правила.


get Allow Invalid()

Возвращает true , если правило отображает предупреждение, когда входные данные не проходят проверку, или false если входные данные полностью отклоняются. По умолчанию для новых правил проверки данных установлено true .

Возвращаться

Booleantrue , если правило разрешает ввод данных, не прошедший проверку; false если нет


get Criteria Type()

Получает тип критерия правила, определенный в перечислении Data ValidationCriteria . Чтобы получить аргументы для критериев, используйте get Criteria Values() . Чтобы использовать эти значения для создания или изменения правила проверки данных, см. Data ValidationBuilder.withCriteria(criteria, args) .

// Log information about the data validation rule for cell A1.
const cell = SpreadsheetApp.getActive().getRange('A1');
const rule = cell.getDataValidation();
if (rule != null) {
  const criteria = rule.getCriteriaType();
  const args = rule.getCriteriaValues();
  Logger.log('The data validation rule is %s %s', criteria, args);
} else {
  Logger.log('The cell does not have a data validation rule.');
}

Возвращаться

Data ValidationCriteria — тип критериев проверки данных.


get Criteria Values()

Получает массив аргументов для критериев правила. Чтобы получить тип критерия, используйте get Criteria Type() . Чтобы использовать эти значения для создания или изменения правила проверки данных, см. Data ValidationBuilder.withCriteria(criteria, args) .

// Log information about the data validation rule for cell A1.
const cell = SpreadsheetApp.getActive().getRange('A1');
const rule = cell.getDataValidation();
if (rule != null) {
  const criteria = rule.getCriteriaType();
  const args = rule.getCriteriaValues();
  Logger.log('The data validation rule is %s %s', criteria, args);
} else {
  Logger.log('The cell does not have a data validation rule.');
}

Возвращаться

Object[] — массив аргументов, соответствующий типу критериев правила; количество аргументов и их тип соответствуют соответствующему методу require...() класса Data ValidationBuilder .


get Help Text()

Получает текст справки по правилу или null , если текст справки не задан.

Возвращаться

String — текст справки по правилу или null , если текст справки не задан.