SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 641|回复: 2
打印 上一主题 下一主题

请教如何利用等位分点数据给一批观察作标记。

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2010-1-24 16:49:24 | 只看该作者

请教如何利用等位分点数据给一批观察作标记。

我有一个数据集A,假设其中有两个变量id,x,我利用univariate过程得到了A集中变量x的等位分点数据25%,50%,75%,结果存在一个新的数据集A_p中。(A_p)只有一个观察,就是x的3个
4分点。现在我需要依据A_p对A中的数据做标记(在A集合中增加一列mark),规则是若x小于25%分点就给相应mark标"A",x大于25%分点但小于50分点就标记"B",等等。请问有什么办法实现?

我现在主要问题是data步(取set A)里中if条件如何引入A_p中的数据?谢谢!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2010-1-24 18:16:36 | 只看该作者

Re: 请教如何利用等位分点数据给一批观察作标记。

[code:2ffhbzrx]proc univariate data=sashelp.class noprint;
        var height;
        output out=temp pctlpts=25 50 75 pctlpre=p_;
run;

data class(drop=p_:);
        set sashelp.class(keep=name height);
        if _n_=1 then set temp;
        if height<=p_25 then mark='A';
        else if p_25<height<=p_50 then mark='B';
run;[/code:2ffhbzrx]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2010-1-24 18:49:40 | 只看该作者

Re: 请教如何利用等位分点数据给一批观察作标记。

嗯,可以用。多谢了! <!-- s:D --><img src="{SMILIES_PATH}/icon_biggrin.gif" alt=":D" title="Very Happy" /><!-- s:D -->
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-6 09:45 , Processed in 0.068544 second(s), 21 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表