SAS SUBSTR

【SAS】SUBSTR関数は文字列から指定した文字数分切り取る。

投稿日:2022年4月25日 更新日:

今回はSUBSTR関数について解説します。


/* 正常形 */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 1, 5);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。

/* あいうえおかきくけこ */
data data1;
  id1="あいうえおかきくけこ";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 1, 5);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 日本語だと表示がおかしくなる。

/* 0, 5 */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 0, 5);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 第2引数に0を設定すると正しく処理されない。

/* 12, 17 */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 12, 17);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 第2引数に最大文字数より大きな値を入れると、id2は欠損値になる。

/* 1, 12 */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 1, 12);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 第3引数が最大文字数より大きくても正しく処理される。

/* 123456789 */
data data1;
  id1=123456789;
    output;
run;


data data2; set data1;
  id2 = substr(id1, 1, 5);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • id1が数値型だと正しく処理されない。

/* "1", "5" */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, "1", "5");	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 第2引数、第3引数が文字型でも正しく表示される。

/* 1.1, 5 */
data data1;
  id1="123456789";
    output;
run;


data data2; set data1;
  id2 = substr(id1, 1.1, 5);	
run;

  • substr関数は設定した字数分の文字列を切り取る。substr(カラム, 開始位置, 文字数)
  • 開始位置は1スタート。
  • 第2引数が1.1でも処理は通る。(1~5を取る。)

-SAS, SUBSTR

執筆者:


comment

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

関連記事

【SAS】ORDER BY句無しで抽出した際の出力順【SQL】

この記事の要約:「ORDER BYを使わない場合、SQLで抽出した際の並び順は保証されない」 SQL文で抽出を行った際に、困ったことが起きました。 同じPG文なのに1回目と2回目で出力結果に違いがある …

【SAS】「引用符で囲まれた文字列の後の識別子の意味は、将来のSASリリースで変わる可能性があります。」の対処法【NOTE】

今回は、 「引用符で囲まれた文字列の後の識別子の意味は、将来のSASリリースで変わる可能性があります。」 とログメッセージが出た時の対処法について解説します。 /* メッセージ_1 */ data d …

【SAS】INPUTは文字型を数値型に変換する

今回はINPUTについて解説します。 /*8桁*/ data work.a; a = input(“20061228”, 8.); run; 文字型⇒数値型への変換はinputを使う。文字型&#822 …

【SAS】オブザベーションを跨いだ計算【RETAIN】【SAS Base Programming対策4】

/* retain */ data data1; Id1=1111; Id2=1111; Id3=1111; output; Id1=2222; Id2=2222; Id3=2222; output; …

【SAS】COALESCEはNULLを数字に置き換える

今回はCOALESCEについて解説します。 /*coalesce 正常形*/ data data1; id=”A”; chiku=1111; output; id=”B”; chiku=2222; o …