CALL SYMPUT SAS

【SAS】CALL SYMPUTは関数を用いてマクロ変数の代入ができる。

投稿日:2021年10月15日 更新日:

今回はCALL SYMPUTについて解説します。


/*その1*/
data data1;
  kyo = today();
run;
  • today()は本日の日付をSAS日付で取得する。

/*その2*/
data data1;
  kyo = put(today(),yymmdd10.);
run;
  • today()は本日の日付をSAS日付で取得する。
  • putにより、today()の値をyymmdd10.形式にしてkyoに代入する。

/*その3*/
%let kyo=2021-10-15;
%put &kyo.;
  • %letでkyoに「2021-10-15」が代入される。

/*その4*/
%let kyo = put(today(),yymmdd10.);
%put &kyo.;
  • その2とその3を合わせて、マクロ変数「kyo」に「put(today(),yymmdd10.)」を代入したいが、関数が計算されずに文字列として代入されてしまっている。
  • 関数はデータセットの中でしか使えない。

/*その5*/
data _NULL_;
  call symput("kyo",put(today(),yymmdd10.));
run;

%put &kyo.;
  • マクロ変数への代入で関数を使いたい場合はCALL SYMPUTを使う。
  • kyoに「2021-10-15」が代入される。

-CALL SYMPUT, SAS

執筆者:


comment

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

関連記事

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

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

【SAS】TITLEステートメントは「結果」にタイトルを付けられる

今回はTITLEステートメントについて解説します。 data data1; 番号=”AAAAAA”; コード=”02″; 金額=1999; output; 番号=”AAAAAA”; コード=”05″; …

【SAS】SASで良く使うテクニック。その2 「Ctrl+R」~データセットの列数が多いとき~【Excel】

今回はSASで良く使うテクニックということで、データセットの列数が多いときは「Ctrl+R」が役に立つ理由を解説していきます。 データセットのコンペアを行う場面を想定します。 先に以下の2記事を読んで …

【SAS】SASで良く使うテクニック。その5 「SUM関数」~データセットの差分がいくつあるのか数えたい時~【Excel】

今回はSASで良く使うテクニックということで、データセットの差分がいくつあるのか数えたいときは「SUM関数」が役に立つ理由を解説していきます。 (参考:【SAS】SASで良く使うテクニック。その1 E …

【SAS】ORDER BYは指定した項目の順番でレコードを並び替える。【SQL】

今回はORDER BYについて解説します。 /* order by_1 */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; I …