!! 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】INPUTステートメントは再帰的に型変換ができない。

今回はINPUTステートメントの再帰的な型変換について解説します。 (なお、通常のINPUT型変換の使い方は以下の記事で解説しています。⇒【SAS】INPUTは文字型を数値型に変換する) /*再帰的型 …

【SAS】STOPステートメントは処理を切り上げる。

今回はSTOPステートメントについて解説していきます。 /* stop1 */ data data1; id1=”1111″; id2=”1111″; id3=”1111″; output; stop …

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

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

【SAS】IFステートメントは処理を分岐できる。その3~サブセットIF~

今回はサブセットIFについて解説していきたいと思います。 (参考:【SAS】IFステートメントは処理を分岐できる。その1 | ビジネスイッチ (how-to-business.com)) (参考:【S …

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

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