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】%MACROはマクロを定義することができる。その5 =を使うと数を渡す引数,数を受け取る引数を指定できる。【%MEND】

今回はマクロ引数に「=」を用いる方法について解説していきたいと思います。(事前に読んでおきたい記事:【SAS】%MACROはマクロを定義することができる。その3 マクロには引数を設定できる。【%MEN …

【SAS】足し算。その2(SUM関数を用いた計算)

今回はSUM関数を用いた足し算について解説します。  (前回は+演算子を用いた足し算について解説しました。⇒【SAS】足し算。その1(+演算子を用いた計算)) /* sum */ data …

【SAS】INDEXC関数は文字列から特定の文字を探して位置を返す。

今回はINDEXC関数について解説します。 data data1; Id1=”1111″; Id2=”1111″; Id3=”1111″; output; Id1=”2111″; Id2=”2111″ …

【SAS】TRANSTRN関数は指定した文字を別の文字に変換する。

/* a */ data data1; Id1=”abcd”; Id2=”ABCD”; output; Id1=”abcd”; Id2=”ABCD”; output; Id1=”abcd”; Id2= …

【SAS】0による除算【SAS Base Programming対策3】

今回は0による除算(割り算)を解説します。 数学では「0で割れない」とか、極限の単元だと「∞に発散する」とか言われますが、SASで0による除算を行うとどうなるのか触れていきます。 知ってるか知らないか …