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】DATAステートメントは複数データセットを出力できる。

今回はDATAステートメントで複数データセットを出力する方法について解説します。 /* data2 data3_1 */ data data1 ; id1=”1111″; id2=”1111″; id …

【SAS】COMPRESS関数は文字列の空白を削除し、詰める。(COMPRESS関数 その1)

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

【SAS】WHEREステートメントはPRINTプロシージャ内で使用ができる。【IFステートメントは使えない】【SAS Base Programming対策6】

/* where */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; Id2=2222; Id3=2222; output; …

【SAS】SASで良く使うテクニック。その10 「矩形選択」~インデントを入れたい時など~【サクラエディタ】

今回はSASで良く使うテクニックということで、ソースコードにインデントを挿入したい時は、「矩形選択」が役に立つ理由を解説していきます。 「矩形選択」は、インデントの挿入以外にも、同じ文字数分削除をした …

【SAS】PRINTプロシージャは入力データセットの中身を結果に表示する【obs=】

今回はPRINTプロシージャについて解説します。 /* print */ data data1; 番号=”AAAAAA”; コード=”02″; 金額=1999; output; 番号=”AAAAAA” …