LoginSignup
0
1

[Google Sheets API] セルに入力規則を設定する

Last updated at Posted at 2024-02-16

Google Sheets API v4(Java)を使用して、
スプレットシートのセルに入力規則を設定する場合、設定可能な内容
についてご紹介します。

セルの入力規則とは
セルに入力するデータを制限したり、設定したルールとは違う入力をしたときに
警告を表示したりできる機能です。

セルの入力規制はDataValidationRuleクラスで指定できますが、
ここでは指定可能な内容のみを記事にしています。

その他のGoogle Sheets APIは、下記の記事を参照ください。
⧉[Google Sheets API] JavaでスプレットシートのメニューとAPIを関連づけてみた

No 目次
1 選択したセルのヘルプオプションを表示
2 データが無効の場合の挙動
3 表示スタイル(プルダウンのみ)
4 適用条件

サンプル コード
入力規則の例を示します。
各々の設定できる内容については以降の記事を参照ください。

public DataValidationRule getDataValidationRule(){
    DataValidationRule rule = new DataValidationRule();
    
    BooleanCondition condition = new BooleanCondition();
    condition.setType("ONE_OF_LIST");   //適用条件
    List<ConditionValue> values = new ArrayList<>();
    ConditionValue value = new ConditionValue();
    values.add(value);
    condition.setValues(values);
    
    rule.setCondition(condition);	    //適用条件
    rule.setInputMessage("これは違うよ");	//選択したセルのヘルプオプションを表示
    rule.setShowCustomUi(false);        //表示スタイル
    rule.setStrict(true);               //データが無効の場合の挙動

    return rule;
}

1. 選択したセルのヘルプオプションを表示

入力規則に反する内容を入力した場合に表示されるダイアログのメッセージを
設定できます。

・メッセージを設定しない(デフォルト)の場合

・メッセージを設定した場合

DataValidationRule rule = new DataValidationRule();
rule.setInputMessage("これは違うよ");

2. データが無効の場合の挙動

データが適用条件に当てはまらない場合の挙動を設定できます。

・入力を拒否(setStric(true))
  セルに入力されたデータは破棄されます。

・警告を表示(setStrict(false))
  セルに入力されたデータはそのまま残り、警告が表示されます。

DataValidationRule rule = new DataValidationRule();
rule.setStrict(true);     //true:入力拒否、false:警告表示

3. 表示スタイル(プルダウンのみ)

セルの表示方法を指定できます。
適用条件が「プルダウン」と「プルダウン(範囲内)」のみ設定が可能です。

・チップ
setShowCustomUi(true)、setStrict(false)

・矢印
setShowCustomUi(true)、setStrict(true)

・書式なしテキスト
setShowCustomUi(false)、setStrict(true)

DataValidationRule rule = new DataValidationRule();
//チップ
rule.setShowCustomUi(true);rule.setStrict(false);
//矢印
//rule.setShowCustomUi(true);rule.setStrict(true);
//書式なしテキスト
//rule.setShowCustomUi(false);rule.setStrict(true);

4. 適用条件

セルに入力した際にチェックする入力規則を設定できます。

例1.プルダウンで「選択項目1」、「選択項目2」が選択する場合

DataValidationRule rule = new DataValidationRule();

BooleanCondition condition = new BooleanCondition();
condition.setType("ONE_OF_LIST");          //「プルダウン」を指定
List<ConditionValue> values = new ArrayList<>();
ConditionValue value1 = new ConditionValue();
value1.setUserEnteredValue("選択項目1");    //選択項目を追加
values.add(value1);
ConditionValue value2 = new ConditionValue();
value2.setUserEnteredValue("選択項目2");    //選択項目を追加
values.add(value2);
condition.setValues(values);

rule.setCondition(condition);	          //適用条件の設定

例2.「本日以前の日付」のみ入力可能な場合

DataValidationRule rule = new DataValidationRule();

BooleanCondition condition = new BooleanCondition();
condition.setType("DATE_ON_OR_BEFORE");  //「指定した日以前の日付」を指定
List<ConditionValue> values = new ArrayList<>();
ConditionValue value = new ConditionValue();
value.setRelativeDate("TODAY");          //「本日」を指定
values.add(value);
condition.setValues(values);

rule.setCondition(condition);	        //適用条件の設定

適用条件を下記一覧にまとめました。

タイトルのtype/RelativeDateは、
タイトルのサブがない場合、BooleanConditionのsetTypeで指定する文字列で、
タイトルのサブがある場合、ConditionValueのsetRelativeDateで指定する文字列です。

タイトルのvalueは、
ConditionValueのsetUserEnteredValueで設定しなければならない数です。
表の数と異なる場合はエラーになります。

条件 サブ type/RelativeDate value
プルダウン ONE_OF_LIST 1〜
プルダウン(範囲内) ONE_OF_RANGE 1
次を含むテキスト TEXT_CONTAINS 1
次を含まないテキスト TEXT_NOT_CONTAINS 1
完全一致するテキスト TEXT_EQ 1
有効なメールアドレスであるテキスト TEXT_IS_EMAIL 0
有効なURLであるテキスト TEXT_IS_URL 0
有効な日付 DATE_IS_VALID 0
日付 DATE_EQ
本日 TODAY 0
明日 TOMORROW 0
昨日 YESTERDAY 0
過去1週間以内 PAST_WEEK 0
過去1ヶ月以内 PAST_MONTH 0
過去1年以内 PAST_YEAR 0
正確な日付 1
次より前の日付 DATE_BEFORE
本日 TODAY 0
明日 TOMORROW 0
昨日 YESTERDAY 0
過去1週間以内 PAST_WEEK 0
過去1ヶ月以内 PAST_MONTH 0
過去1年以内 PAST_YEAR 0
正確な日付 1
指定した日以前の日付 DATE_ON_OR_BEFORE
本日 TODAY 0
明日 TOMORROW 0
昨日 YESTERDAY 0
過去1週間以内 PAST_WEEK 0
過去1ヶ月以内 PAST_MONTH 0
過去1年以内 PAST_YEAR 0
正確な日付 1
次より後の日付 DATE_AFTER
本日 TODAY 0
明日 TOMORROW 0
昨日 YESTERDAY 0
正確な日付 1
指定した日以降の日付 DATE_ON_OR_AFTER
本日 TODAY 0
明日 TOMORROW 0
昨日 YESTERDAY 0
正確な日付 1
指定した期間内の日付 DATE_BETWEEN 2
指定した期間外の日付 DATE_NOT_BETWEEN 2
次より大きい NUMBER_GREATER 1
以上 NUMBER_GREATER_THAN_EQ 1
次より小さい NUMBER_LESS 1
以下 NUMBER_LESS_THAN_EQ 1
次と等しい NUMBER_EQ 1
次と等しくない NUMBER_NOT_EQ 1
次の間にある NUMBER_BETWEEN 2
次の間にない NUMBER_NOT_BETWEEN 2
チェックボックス BOOLEAN 0 or 2
カスタム数式 CUSTOM_FORMULA 1

おしまい。。

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1