SAS中文论坛

标题: 请教如何利用等位分点数据给一批观察作标记。 [打印本页]

作者: shiyiming    时间: 2010-1-24 16:49
标题: 请教如何利用等位分点数据给一批观察作标记。
我有一个数据集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中的数据?谢谢!
作者: shiyiming    时间: 2010-1-24 18:16
标题: 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]
作者: shiyiming    时间: 2010-1-24 18:49
标题: Re: 请教如何利用等位分点数据给一批观察作标记。
嗯,可以用。多谢了! <!-- s:D --><img src="{SMILIES_PATH}/icon_biggrin.gif" alt=":D" title="Very Happy" /><!-- s:D -->




欢迎光临 SAS中文论坛 (https://mysas.net/forum/) Powered by Discuz! X3.2