ELSE DO END IF SAS THEN DO

【SAS】IFステートメントは処理を分岐できる。その4~THEN DO, ELSE DO~【END】

投稿日:

今回はIF文の分岐で、複数の命令を実行する方法について、解説していきます。

【併せて読みたい記事】


/* then do_1 */
data data1;
 id1="1111"; id2="1111"; id3="1111";
   output;
run;

data data2; set data1;
  if id1 = "1111" then do;
    id4 = "1111";
    id5 = "1111";
  end;
  else if id1 = "2222" then do;
    id4 = "2222";
    id5 = "2222";
  end;
  else do;
    id4 = "3333";
    id5 = "3333";
  end;
run;
  • then do~end, else do~endを使う事で、複数の命令文を実行できる。
  • 最初のifステートメントがTRUEであるため、id4 = “1111” id5=”1111″となる。

/* then do_2 */
data data1;
 id1="2222"; id2="2222"; id3="2222";
   output;
run;

data data2; set data1;
  if id1 = "1111" then do;
    id4 = "1111";
    id5 = "1111";
  end;
  else if id1 = "2222" then do;
    id4 = "2222";
    id5 = "2222";
  end;
  else do;
    id4 = "3333";
    id5 = "3333";
  end;
run;
  • then do~end, else do~endを使う事で、複数の命令文を実行できる。
  • 第2文のelse ifステートメントがTRUEであるため、id4 = “2222” id5=”2222″となる。

/* then do_3 */
data data1;
 id1="3333"; id2="3333"; id3="3333";
   output;
run;

data data2; set data1;
  if id1 = "1111" then do;
    id4 = "1111";
    id5 = "1111";
  end;
  else if id1 = "2222" then do;
    id4 = "2222";
    id5 = "2222";
  end;
  else do;
    id4 = "3333";
    id5 = "3333";
  end;
run;
  • then do~end, else do~endを使う事で、複数の命令文を実行できる。
  • 第3文のelse doステートメントがTRUEであるため、id4 = “3333” id5=”3333″となる。

/* end無し_1 */
data data1;
 id1="1111"; id2="1111"; id3="1111";
   output;
run;

data data2; set data1;
  if id1 = "1111" then do;
    id4 = "1111";
    id5 = "1111";
  else if id1 = "2222" then do;
    id4 = "2222";
    id5 = "2222";
  else do;
    id4 = "3333";
    id5 = "3333";
run;
  • then do~end, else do~endを使う事で、複数の命令文を実行できる。
  • DOブロックに対して、ENDで閉じてないとエラーとなる。

-ELSE DO, END, IF, SAS, THEN DO

執筆者:


comment

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

関連記事

【SAS】%MACROはマクロを定義することができる。その3 マクロには引数を設定できる。【%MEND】

今回はマクロに引数を設定する方法について解説していきたいと思います。(事前に読んでおきたい記事:【SAS】%MACROはマクロを定義することができる。【%MEND】 | ビジネスイッチ (how-to …

【SAS】COMPAREはデータセットの比較に便利

今回はCOMPAREについて解説します。 /* 正常形 */ data data1; id=”A”; chiku=”SHINJUKU”; output; id=”B”; chiku=”ICHIGAYA …

【SAS】SASで良く使うテクニック。その7 「条件付き書式」~差分があるセルに色を付けたい時~【Excel】

今回はSASで良く使うテクニックということで、データセットのコンペアにおいて、差分があるセルに色を付けたい時ときは「条件付き書式」が役に立つ理由を解説していきます。 (参考:【SAS】SASで良く使う …

SAS Base Programmingの資格を取りました。試験の流れを解説します。[出題された問題のリークも]

仕事でSASというプログラミング言語を使用してるのですが、 SASの資格を欲しいと思って先日、SASの試験Base Programmingを受けてきました。 2021年内に2回受験をして、 1回目は不 …

【SAS】TRANSPOSEは縦持ち、横持ちを変換できる。その1

今回はTRANSPOSEについて解説します。 /* num char char */ data data1; NO=1111; CHAR=”A”; MOJI=”AAAA”; output; NO=22 …