楼主: hytc0095
3049 3

加急:sas 对行排序 [推广有奖]

  • 3关注
  • 0粉丝

大专生

88%

还不是VIP/贵宾

-

威望
0
论坛币
94 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
2497 点
帖子
47
精华
0
在线时间
82 小时
注册时间
2012-4-18
最后登录
2023-10-31

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

想要做个对行排序,
原始数据如下:
data x;
input name$ english chinese nature@@ ;
  call symputx(cats("name",_n_),name);
cards;
A 95 96 96
B 96 91 80
C 92 94 98
;

想要得到下面的数据集:
1 A chinese nature english
2 B english chinese nature
3 C nature chinese nature

即:每一行都是排序的!
二维码

扫码加我 拉你入群

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

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

关键词:Chinese English Nature Englis symput english nature

回帖推荐

yongyitian 发表于2楼  查看完整内容

沙发
yongyitian 发表于 2013-7-22 10:25:44 |只看作者 |坛友微信交流群
  1. data x;
  2. input name$ English Chinese Nature@@ ;
  3.   call symputx(cats("name",_n_),name);
  4. cards;
  5. A 95 96 94
  6. B 96 91 80
  7. C 92 94 98
  8. ;

  9. data want;
  10.     array xx {3} english chinese nature;
  11.     array cc {3} $10. c1-c3;
  12.     array dd{3} $10. d1-d3;
  13.     set x;
  14.     do i = 1 to dim(xx);
  15.       cc(i) = catx('_', put(xx(i), 3.), vname(xx(i)));
  16.     end;
  17.     call sortc(of cc{*});
  18.     do i = 1 to dim(xx);
  19.        j = dim(xx) - i + 1;
  20.        dd( j ) = scan(cc(i), 2,'_');
  21.     end;
  22.     keep name d1-d3;
  23. run;
复制代码
已有 2 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
boe + 1 + 1 + 1 精彩帖子,给你发信了
Imasasor + 80 + 80 + 4 + 2 + 2 热心帮助其他会员

总评分: 经验 + 80  论坛币 + 80  学术水平 + 5  热心指数 + 3  信用等级 + 3   查看全部评分

使用道具

藤椅
hytc0095 发表于 2013-7-22 10:42:54 |只看作者 |坛友微信交流群
yongyitian 发表于 2013-7-22 10:25

谢谢!太厉害了!

使用道具

板凳
oneoneagain 发表于 2013-8-22 19:24:59 |只看作者 |坛友微信交流群
学习了!

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-26 12:42