%MACRO %MEND = SAS

【SAS】%MACROはマクロを定義することができる。その5 =を使うと数を渡す引数,数を受け取る引数を指定できる。【%MEND】

投稿日:

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


/* %macro act1(no=)  %act1(no=1)*/
%macro act1(no=);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

%mend;



%act1(no=1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(no=1);で「no」に1を渡している。
  • %macro act1(no=);で「no」の引数を受け取っている。
  • データセット名は「DATA1」

/* %macro act1(no1=)  %act1(no=1)*/
%macro act1(no1=);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

%mend;



%act1(no=1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(no=1);で「no」に1を渡している。
  • %macro act1(no1=);で「no1」の引数を受け取っている。
  • 数を渡すべき「no」が無いため、エラー

/* %macro act1(no=) %act1(1) */
%macro act1(no=);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

%mend;



%act1(1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(1);で格納先を指定せずに1を渡している。
  • %macro act1(no=);で「no」の引数を受け取っている。
  • 「no」が1を受け取れていないため、エラー

/* %macro act1(no) %act1(no=1) */
%macro act1(no);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

%mend;



%act1(no=1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(no=1);で「no」に1を渡している。
  • %macro act1(no);で「no」の引数を受け取っている。
  • データセット名は「DATA1」

/* %macro act1(no1) %act1(no=1) */
%macro act1(no1);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

%mend;



%act1(no=1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(no=1);で「no」に1を渡している。
  • %macro act1(no1);で「no1」の引数を受け取とうとしている。
  • 数を渡すべき「no」が無いため、エラー

/* %macro act1(no=,no1=) %act1(no=1) */
%macro act1(no=,no1=);

  data data&no.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;

  data data&no1.;
    id1="1111"; id2="1111"; id3="1111";
      output;
    id1="2222"; id2="2222"; id3="2222";
      output;
    id1="3333"; id2="3333"; id3="3333";
      output;
  run;


%mend;



%act1(no=1);

  • %macro~%mendでマクロを定義することができる。
  • %act1(no=1);で「no」に1を渡している。
  • %macro act1(no=,no1=);で「no」「no1」の引数を受け取っている。
  • 「no=1」によりデータセット名①は「DATA1」
  • 「no1=null」によりデータセット名②は「DATA」

-%MACRO, %MEND, =, SAS

執筆者:


comment

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

関連記事

【SAS】INTCK関数を使って年齢計算をする。【PUT】【SUBSTR】【IF】

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

【SAS】ATTRIBとRENAMEを同時に使うときの注意点

今回はATTRIBとRENAMEを同時に使うときに注意するべきポイントについて解説していきます。 SAS日付となっているid1をddMONyyyy形式にして、id4とするケースを仮定します。 結論:A …

【SAS】ARRAYステートメントは配列を設定することができる。その2

今回はarrayステートメント(その2)について解説します。 以前、過去記事でarrayステートメントについて解説していました。⇒【SAS】ARRAYステートメントは配列を設定することができる。 | …

【SAS】SASで日付を扱う(年月日)【”d】 【YEAR()】【MONTH()】【DAY()】【MDY()】

今回は日付を用いた様々な操作について解説します。  /*”d*/ data data1; Id1 = ’03jan2022’d; run; ’03jan2022’d …

【SAS】SCAN関数は区切り文字を認識し、一部を抜き出せる。

今回はSCAN関数について解説します。 /* “1111”,”2222″,”3333″ */ data data1; Id1=”1111″,”2222″,”3333″; run; data data2 …