楼主: Laughing06
2353 6

用SAS按固定列数产生新的变量值 [推广有奖]

  • 4关注
  • 0粉丝

大专生

65%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
499 点
帖子
37
精华
0
在线时间
51 小时
注册时间
2013-3-13
最后登录
2016-5-3

楼主
Laughing06 发表于 2014-5-16 21:25:59 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
e.g.:数据集如下:就是想产生一个新的变量visit,使输出结果为:
lesnum                                                                                     lesnum      visit
T1                                                                                            T1             V1
T2                                                                                            T2             V1               
T3                                                                                            T3             V1
T1                                                                                            T1             V2

T2                                                                                            T2             V2
T3                                                                                            T3             V2
T1                                                                                            T1             V3
T2                                                                                            T2             V3
T3                                                                                            T3             V3

即,刚开始的变量lesnum是三个一循环,新生成的变量visit是对应的每三行自动+1,从V1开始。
不知哪位大神给解答一下,需要用什么语句。小弟先谢过了。

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:变量值 Visit visi 输出结果 les visit

沙发
zhengbo8 发表于 2014-5-16 22:39:15
  1. data a;
  2.         input lesnum  $;
  3. datalines;
  4. T1
  5. T2
  6. T3
  7. T1
  8. T2
  9. T3
  10. T1
  11. T2
  12. T3
  13. ;

  14. proc sort data=a;by lesnum ;run;

  15. data b;
  16.   set a;
  17.   by lesnum ;
  18.   length visit $ 8;
  19.   retain index 0;
  20.   if first.lesnum then index=1;else index=index+1;
  21.   visit=cat('V',index);
  22. run;

  23. proc sort data=b;by index;run;

  24. data b(drop=index);
  25.         set b;
  26. run;
复制代码

藤椅
mingfeng07 学生认证  发表于 2014-5-16 22:49:26
  1. data test(drop=k);
  2. set a;
  3. if mod(_n_,3)=1 then k=1;
  4. else k+1;
  5. visit='V'||compress(k);
  6. run;
复制代码
欢迎扫一扫我头像关注, 不定期分享SAS技术知识。

板凳
Laughing06 发表于 2014-5-17 12:51:38
zhengbo8 发表于 2014-5-16 22:39
非常感谢,可以实现。有个小问题,row21:retain index 0;  这个"0"有什么用,不加的话也没问题啊。。。

报纸
Laughing06 发表于 2014-5-17 12:52:11
mingfeng07 发表于 2014-5-16 22:49
不好意思,你这个和我想达到的目的不一样。

地板
zhengbo8 发表于 2014-5-17 13:24:25
累加初始值,最好提供,减少出错可能。

7
Laughing06 发表于 2014-5-17 14:32:22
zhengbo8 发表于 2014-5-17 13:24
累加初始值,最好提供,减少出错可能。
soga. 受教了 多谢

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-29 14:07