!! SAS SUBSTR ||

【SAS】YYYY-MM表記にする方法【SUBSTR】【||】

投稿日:2023年3月26日 更新日:

今回はYYYYMMDD表記の年月日をYYYY-MM表記にしたいと思います。

結論:SUBSTRと||を使います。

(SUBSTR:【SAS】SUBSTR関数は文字列から指定した文字数分切り取る。 | ビジネスイッチ (how-to-business.com)

(||:【SAS】||(!!)は文字列の連結ができる。【結合】 | ビジネスイッチ (how-to-business.com)

YYYYMM表記であれば、put(○○,yymmn.)で簡単に作れるのですが、

(PUT:【SAS】PUTはSAS日付値をフォーマットを変換して表示する【DATE】【YYMMDD】【DATETIME】【TIME】【TOD】 | ビジネスイッチ (how-to-business.com)

ハイフン付(YYYY-MM)はputによる日付変換では作成できません。


/* yymmn */
data data1;
  id1 = "20230326";
run;

data data2; set data1;
  id2 = input(id1, yymmdd8.);
  id3 = put(id2, yymmn.);
run;

/* yymm */
data data1;
  id1 = "20230326";
run;

data data2; set data1;
  id2 = input(id1, yymmdd8.);
  id3 = put(id2, yymm.);
run;

/* yymmdd6 */
data data1;
  id1 = "20230326";
run;

data data2; set data1;
  id2 = input(id1, yymmdd8.);
  id3 = put(id2, yymmdd6.);
run;

/* substr */
data data1;
  id1 = "20230326";
run;


data data2; set data1;
  id2 = substr(id1, 1, 4);
  id3 = substr(id1, 5, 2);
  id4 = compress(id2||"-"||id3);
run;

なお、YYYY/MM表記でもSUBSTRと||を用いる必要があります。


/* substr_2 */
data data1;
  id1 = "20230326";
run;


data data2; set data1;
  id2 = substr(id1, 1, 4);
  id3 = substr(id1, 5, 2);
  id4 = compress(id2||"/"||id3);
run;

-!!, SAS, SUBSTR, ||

執筆者:


comment

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

関連記事

【SAS】PRINTプロシージャは入力データセットの中身を結果に表示する【obs=】

今回はPRINTプロシージャについて解説します。 /* print */ data data1; 番号=”AAAAAA”; コード=”02″; 金額=1999; output; 番号=”AAAAAA” …

【SAS】^=(ノットイコール)

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

【SAS】SUBSTR関数は文字列から指定した文字数分切り取る。その2 再帰的使用

今回はSUBSTR関数の再帰的使用について解説していきます。 /* 再帰的 */ data data1; id1=”123456789″; output; run; data data2; set d …

【SAS】PATHNAME関数はライブラリのディレクトリパスを返す

今回はPATHNAME関数について解説します。 data data1; Id1 = pathname(“work”); run; pathnameによりライブラリworkのディレクトリパスを代入できる …

【SAS】SETステートメントに複数データセットを設定すると縦結合できる

今回はSETについて解説します。 /* 1~7 */ data data1; Id1=1111; Char1=”AAAA”; output; Id1=2222; Char1=”BBBB”; outpu …