SAS SET

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

投稿日:2021年11月7日 更新日:

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


/* 1~7 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=5555; Char1="EEEE";
    output;
  Id1=6666; Char1="FFFF";
    output;
  Id1=7777; Char1="GGGG";
    output;
run;


data data3;
  set data1 data2;
run;

  • SETステートメントに複数データセットを設定すると縦に結合する。

/* 1~4 1~4 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


data data3;
  set data1 data2;
run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 一致する値が有っても機械的に縦に結合する。(mergeではない点に注意)

/* char1 char2 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=5555; Char2="EEEE";
    output;
  Id1=6666; Char2="FFFF";
    output;
  Id1=7777; Char2="GGGG";
    output;
run;


data data3;
  set data1 data2;
run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 片方のテーブルにしか存在しない変数は両方採用される。

/* Id1 Char1 Id2 Char2 */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id2=5555; Char2="EEEE";
    output;
  Id2=6666; Char2="FFFF";
    output;
  Id2=7777; Char2="GGGG";
    output;
run;


data WORK.data3;
  set data1 data2;
run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 片方のテーブルにしか存在しない変数は両方採用される。

/* 1~7 by */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=5555; Char1="EEEE";
    output;
  Id1=6666; Char1="FFFF";
    output;
  Id1=7777; Char1="GGGG";
    output;
run;



  data WORK.data3;
     set data1 data2;
     by Id1;
  run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • byに指定した変数に従ってレコードを並び替える。

/* 1~4 1~4 by */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;


  data WORK.data3;
     set data1 data2;
     by Id1;
  run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 一致する値が有っても縦に結合する。(mergeではない点に注意)
  • byに指定した変数に従ってレコードを並び替える。

/* char1 char2 by */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1=5555; Char2="EEEE";
    output;
  Id1=6666; Char2="FFFF";
    output;
  Id1=7777; Char2="GGGG";
    output;
run;



  data WORK.data3;
     set data1 data2;
     by Id1;
  run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 片方のテーブルにしか存在しない変数は両方採用される。
  • byに指定した変数に従ってレコードを並び替える。

/* Id1 Char1 Id2 Char2 by */
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id2=5555; Char2="EEEE";
    output;
  Id2=6666; Char2="FFFF";
    output;
  Id2=7777; Char2="GGGG";
    output;
run;


  data WORK.data3;
     set data1 data2;
     by Id1;
  run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 片方のテーブルにしか存在しない変数は両方採用される。
  • byに指定した変数に従ってレコードを並び替える。
  • byに指定した変数が入力データセットに存在しないとエラーとなる。

/*型違い*/
data data1;
  Id1=1111; Char1="AAAA";
    output;
  Id1=2222; Char1="BBBB";
    output;
  Id1=3333; Char1="CCCC";
    output;
  Id1=4444; Char1="DDDD";
    output;
run;

data data2;
  Id1="eeee"; Char1="EEEE";
    output;
  Id1="ffff"; Char1="FFFF";
    output;
  Id1="gggg"; Char1="GGGG";
    output;
run;


data data3;
  set data1 data2;
run;

  • SETステートメントに複数データセットを設定すると縦に結合する。
  • 同じ名前の変数が型違いで入力データセットに含まれているとエラーとなる。

-SAS, SET

執筆者:


comment

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

関連記事

【SAS】SASUSERライブラリの性質について解説

今回はSASUSERライブラリについて解説します。(対比参考:【SAS】WORKライブラリの性質について解説 | ビジネスイッチ (how-to-business.com)) libnameを使わなく …

【SAS】WHEREステートメントはPRINTプロシージャ内で使用ができる。【IFステートメントは使えない】【SAS Base Programming対策6】

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

【SAS】SAS Studio上でカラムの順番を変える方法

今回はSAS Studio上でカラムの順番を変える操作について解説します。 ちなみにカラムの出力順をプログラムで制御する方法は過去の記事で解説しています。(参考:【SAS】FORMATはカラムの出力順 …

【SAS】SASで良く使うテクニック。その11「Ctrl+/」~範囲指定でコメントを入れたい時~【SAS Studio】

今回はSASで良く使うテクニックということで、範囲指定でコメントを入れたい時は、「Ctrl+/」が役に立つ理由を解説していきます。 以下のようにソースコードを準備します。(ソースコードの内容は何でも良 …

【SAS】SAS Studioのフィルター機能の使い方を解説 その1 ~文字型~

今回はSAS Studioのフィルター機能について解説します。 /* 文字型 */ data data1; id1=”1111″; id2=”1111″; id3=”1111″; output; id …