2

次の形式のデータ セットがあるとします。

ID  Product account open date  
1   A   20100101  
1   B   20100103  
2   C   20100104  
2   A   20100205  
2   D   20100605  
3   A   20100101  

そして、開いた製品のシーケンスをキャプチャする列を作成して、テーブルが次のようになるようにします。

ID  First   Second  third  
1   A   B   
2   C   A   D  
3   A       

後でデータを転置できるように、ID ごとにインデックスを作成する必要があることはわかっています。

ID  Product account open date   sequence  
1   A   20100101    1  
1   B   20100103    2  
2   C   20100104    1  
2   A   20100205    2  
2   D   20100605    3  
3   A   20100101    1 

do ループに関する私の限られた知識から、次のようなものを書く必要があると思います:
if first.ID and not last.ID then n=1 do while ID not last n+1

そんな感じ。誰でも正確な構文で私を助けることができますか? 同様のコードをグーグルで検索してみましたが、うまくいきませんでした。

ありがとう!

4

1 に答える 1

2

簡単にするために、ID で並べ替えてから日付を付け、proc 転置を使用します。次に例を示します。

data prod;
input ID Product $ Open_DT :yymmdd8.;
format open_dt date9.;
datalines;
1 A 20100101
1 B 20100103
2 C 20100104
2 A 20100205
2 D 20100605
3 A 20100101
;
run;
proc sort data=prod;
  by ID Open_DT;run;
proc transpose data=prod 
  out=prod_trans(drop=_name_)
    prefix=ITEM;
  by id;
  var Product;
run;

proc print data=prod_trans noobs;
run;
于 2011-03-24T23:15:26.890 に答える