!! 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】PUTLOGステートメントは文字列をログに出力する。

今回はPUTLOGについて解説します。 /* putlog_1 */ data _null_; putlog ‘2022/03/26’; run; putlogにより、ログに文字列を出力できる。%pu …

【SAS】SUMMARYは集計に便利

今回はSUMMARYについて解説します。 /*正常形*/ data data1; 契約番号=”AAAAAA”; 会社コード=”02″; 請求金額=4999; output; 契約番号=”AAAAAA” …

【SAS】SUMは足し算をする。その1【SQL】

今回はSQLのSUMについて解説します。 /* SUM_1 */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; Id2=222 …

【SAS】LIBNAMEステートメントはExcelファイルをライブラリとして割り当てることができる。【SAS Base Programming対策5】

今回はLIBNAMEステートメントを用いてExcelファイルをライブラリ参照する方法について触れていきます。 SAS Base Programmingの試験を2回受験しましたが、2回ともExcelファ …

【SAS】SUMは足し算をする。その2【要約関数】【SQL】

今回もSQLのSUM(要約関数)について解説します。 過去記事でも、SQLのSUM関数について取り上げました。【SAS】SUMは足し算をする。その1【SQL】 | ビジネスイッチ (how-to-bu …