SAS WHERE

【SAS】WHEREステートメントはIFステートメントと同様に処理条件を設定できる。(分岐)

投稿日:2021年12月3日 更新日:

今回はWHEREステートメントについて解説します。


/* where */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111, 2222, 3333);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。

/* where 条件1つ */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。(条件が1つでも使える)

/* where 条件文字列 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Char1 in ("AAAA", "BBBB", "CCCC");
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 文字列型でも設定できる。

/* where 数値型と文字列 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in ("AAAA", "BBBB", "CCCC");
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 文字列型でも設定できる。
  • 型が合っていないとエラーとなる。

/* 5555,6666,7777 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (5555, 6666, 7777);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • 条件に合う値が無いと0レコードのデータセットが出力される。

/* where or */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1=1111 or Id1=2222 or Id1=3333;
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略せずに、通常通り記載することもできる。

data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1=1111 and Char1="AAAA";
run;

  • whereを用いて処理条件を設定できる。
  • if文と同様、andも使える。

/*where文が複数*/
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data2; set data1;
  where Id1 in (1111, 2222, 3333);
  where Id1 in (1111, 4444);
run;

  • whereを用いて処理条件を設定できる。
  • or条件を簡略して記載できる。
  • where文が複数あるとき、最後のwhere文が優先される。

-SAS, WHERE

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

【SAS】SUBSTR関数を使って右から文字列を切り取る方法について解説【LENGTHN】

今回はSUBSTR関数を使って右から文字列を切り取る方法について解説します。 (参考:【SAS】SUBSTR関数は文字列から指定した文字数分切り取る。 | ビジネスイッチ (how-to-busine …

【SAS】IF文はデータ読み込み後にフィルター、WHERE文はデータ読み込み時にフィルターをする。

今回は、データ入力に着目して、IF文とWHERE文の違いを解説します。 /* if */ data data1; Id1=1111; Char1=”AAAA”; output; Id1=2222; C …

【SAS】NODUPはソート時に全ての変数における重複を削除する

今回はNODUPについて解説します。 前回NODUPKEYについて解説しました。 【SAS】NODUPKEYはソート時に重複を削除する 今回のNODUPは前回の文法の亜種という感じです。 /*nodu …

【SAS】TRIM関数は文字列の連結時に末尾のスペースを除去できる。

今回はTRIM関数について解説します。 /* trim */ data data1; Id1=1111; Char1=”AA AA”; output; Id1=2222; Char1=” BBBB”; …

【SAS】INPUTステートメントは再帰的に型変換ができない。

今回はINPUTステートメントの再帰的な型変換について解説します。 (なお、通常のINPUT型変換の使い方は以下の記事で解説しています。⇒【SAS】INPUTは文字型を数値型に変換する) /*再帰的型 …