楼主: leedx
3127 18

[原创博文] 每天一题,练练手 [推广有奖]

11
leedx 发表于 2011-2-22 21:44:58
自己顶一个先,问题是这样的。
考虑数据集
name      grade
sarah       A
emma     A
sam        B
john        C
将grade为A的更新为“优秀”,B的更新为“良好”,C的更新为“合格”。
大家看看有多少种编程的方法?

12
leedx 发表于 2011-2-23 10:34:16
自己顶一个,方法一:用sql
data a;
   input name$ grade$;
cards;
sarah       A
emma     A
sam        B
john        C
;
run;

proc sql;
   update a set grade=
   case grade when 'A' then "优秀"
                        when 'B' then "良好"
                       else "及格"
   end;
   select * from a;
quit;



方法二:用if语句
data a;
   input name$ grade$;
cards;
sarah       A
emma     A
sam        B
john        C
;
run;
data b;
   set a;
   if grade="A" then grade="优秀";
   if grade="B" then grade="良好";
   if grade="C" then grade="及格";
run;
已有 1 人评分学术水平 收起 理由
Actree + 1 不错

总评分: 学术水平 + 1   查看全部评分

13
baoaibaobao 发表于 2011-2-23 10:45:03
  1. *method 1;
  2. data zachary1;
  3.         input name$ grade$;
  4.         if grade='A' then grade='优秀';
  5.                 else if grade='B' then grade='良好';
  6.                         else grade='合格';
  7. cards;
  8. sarah    A
  9. emma     A
  10. sam      B
  11. john     C
  12. ;
  13. run;
  14. *method 2;
  15. data zachary2;
  16.         input name$ grade$;
  17.         select(grade);
  18.                 when('A') grade='优秀';
  19.                 when('B') grade='良好';
  20.                 otherwise grade='合格';
  21.         end;
  22. cards;
  23. sarah    A
  24. emma     A
  25. sam      B
  26. john     C
  27. ;
  28. run;
复制代码
已有 2 人评分经验 学术水平 热心指数 收起 理由
crackman + 20 + 1 鼓励积极发帖讨论
Actree + 1 不错

总评分: 经验 + 20  学术水平 + 1  热心指数 + 1   查看全部评分

14
leedx 发表于 2011-2-23 14:32:41
恩,希望看到更多更好的解法~

15
ttqqqq 发表于 2011-2-23 16:24:51
支持。。。。。。。。。

16
leedx 发表于 2011-2-23 23:39:48
问题二:有如下两个数据集
one
num        var1
1              A
1              A
2              B
3              C

TWO
NUM      VAR1
1             A
4             Y
4             Z

找出属于数据集one而不属于数据集two的部分;找出数据集one和two的公共部分?

17
leedx 发表于 2011-2-23 23:40:06
问题二:有如下两个数据集
one
num        var1
1              A
1              A
2              B
3              C

TWO
NUM      VAR1
1             A
4             Y
4             Z

找出属于数据集one而不属于数据集two的部分;找出数据集one和two的公共部分?

18
leedx 发表于 2011-2-24 17:31:16
自己顶一个
  1. data one;
  2. input num var1$;
  3. cards;
  4. 1              A
  5. 1              A
  6. 2              B
  7. 3              C
  8. ;
  9. run;

  10. data TWO;
  11. input num var1$;
  12. cards;
  13. 1             A
  14. 4             Y
  15. 4             Z
  16. ;
  17. run;
  18. 属于one 但不属于two
  19. 方法一:
  20. proc sql;
  21.    select * from one left join two
  22.    on one.num=two.num;
  23. quit;

  24. 方法二:
  25. data three;
  26.    merge one(in=a) two(in=b);
  27.    by num;
  28.    if a=1 and b=0 then output;
  29. run;
复制代码
已有 1 人评分经验 热心指数 收起 理由
crackman + 20 + 1 鼓励积极发帖讨论

总评分: 经验 + 20  热心指数 + 1   查看全部评分

19
leedx 发表于 2011-2-26 14:22:35
没人支持,自己顶一个~

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-2 03:18