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】INTCK関数を使って年齢計算をする。【PUT】【SUBSTR】【IF】

今回はINTCK関数を使って、年齢計算を行う方法について解説していきたいと思います。 併わせて読みたい記事 (INTCK:【SAS】INTCK関数は指定された区間に指定された単位を何回跨ぐか数える。 …

【SAS】INPUTは日付表記をSAS日付に変換できる

今回はINPUT関数を使って日付表記をSAS日付に変換する方法について解説します。  /* “2022/01/04” */ data data1; a = “2022/01/04”; b = …

【SAS】足し算。その1(+演算子を用いた計算)

今回は+演算子を用いた足し算について解説します。  /* + */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; I …

【SAS】「引用符で囲まれた文字列の後の識別子の意味は、将来のSASリリースで変わる可能性があります。」の対処法【NOTE】

今回は、 「引用符で囲まれた文字列の後の識別子の意味は、将来のSASリリースで変わる可能性があります。」 とログメッセージが出た時の対処法について解説します。 /* メッセージ_1 */ data d …

【SAS】SAS Studioのフィルター機能の使い方を解説 その1 ~文字型~

今回はSAS Studioのフィルター機能について解説します。 /* 文字型 */ data data1; id1=”1111″; id2=”1111″; id3=”1111″; output; id …