楼主: dxystata
462 4

[有偿编程] 如何根据每个第一行的x的取值排序 [推广有奖]

版主

大师

35%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
181616 个
通用积分
15235.7814
学术水平
208 点
热心指数
271 点
信用等级
174 点
经验
293425 点
帖子
5421
精华
1
在线时间
13525 小时
注册时间
2006-6-21
最后登录
2024-6-2

初级学术勋章 初级热心勋章 中级热心勋章 初级信用勋章

50论坛币
复制代码
  1. data aaa;
  2. input var1$ var2$ x;
  3. cards;
  4. aa aa 5
  5. 轻 aa 3
  6. 中 aa 2
  7. 重 aa 0
  8. bb bb 8
  9. 轻 bb 5
  10. 中 bb 3
  11. 重 bb 0
  12. cc cc 6
  13. 轻 cc 6
  14. 中 cc 0
  15. 重 cc 0
  16. ;
  17. run;
复制代码



如何按照aa、bb、cc第一行是合计,现在根据第一行的x的取值排序,但属于aa、bb、cc的轻、中、重不变。

得到的结果应是
bb bb 8
轻 bb 5
中 bb 3
重 bb 0
cc cc 6
轻 cc 6
中 cc 0
重 cc 0
aa aa 5
轻 aa 3
中 aa 2
重 aa 0

轻中重只是举例,也可能是1级 2级 3 级 4级等等。希望程序能通用,谢谢!



最佳答案

乐天天12300 查看完整内容

proc sort data=aaa; by var2; run; data bbb; set aaa; by var2; retain y; if first.var2 then y=x; run; proc sort data=bbb out=ccc(drop=y); by descending y; run;
关键词:cards Input Data card VaR
沙发
乐天天12300 发表于 2022-2-23 10:03:03 |只看作者 |坛友微信交流群
proc sort data=aaa;
    by var2;
run;

data bbb;
    set aaa;
    by var2;
    retain y;
    if first.var2 then y=x;
run;

proc sort data=bbb out=ccc(drop=y);
    by descending y;
run;
已有 1 人评分经验 学术水平 热心指数 收起 理由
dxystata + 100 + 1 + 1 热心帮助其他会员

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

使用道具

藤椅
dxystata 发表于 2022-2-23 10:04:14 |只看作者 |坛友微信交流群
微信截图_20220223100319.png


data aaa;
input var1$ var2$ x;
cards;
aa aa 5
轻 aa 3
中 aa 2
重 aa 0
bb bb 8
轻 bb 5
中 bb 3
重 bb 0
cc cc 6
轻 cc 6
中 cc 0
重 cc 0
;
run;

使用道具

板凳
HXAI102230 在职认证  发表于 2022-2-23 10:48:31 |只看作者 |坛友微信交流群
下面的代码是不是满足要求?

使用道具

报纸
HXAI102230 在职认证  发表于 2022-2-23 10:49:33 |只看作者 |坛友微信交流群
data aaa;
input var1 $ var2 $ x;
cards;
ttl aa 5
l1 aa 3
l2 aa 2
l3 aa 0
ttl bb 8
l1 bb 5
l2 bb 3
l3 bb 0
ttl cc 6
l1 cc 6
l2 cc 0
l3 cc 0
;
run;

proc transpose data=aaa out=bbb;
  by var2;
        id var1;
        var x;
run;

proc sort data=bbb;
  by descending ttl;
run;

data ccc;
  set bbb;
        array level{4} ttl l1 l2 l3;
        do i=1 to 4;
    if ^missing(level{i}) then levelv=level{i};
                varname=vname(level{i});
                output;       
        end;  
        keep var2 varname levelv;
run;

已有 1 人评分经验 热心指数 收起 理由
dxystata + 100 + 1 热心帮助其他会员

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

使用道具

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

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

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

GMT+8, 2024-6-2 15:09