楼主: 小鳄鱼a
3469 11

求助如何按条件统计缺省值 [推广有奖]

  • 6关注
  • 10粉丝

学科带头人

3%

还不是VIP/贵宾

-

威望
0
论坛币
125 个
通用积分
0.0040
学术水平
40 点
热心指数
45 点
信用等级
43 点
经验
32801 点
帖子
1185
精华
0
在线时间
1539 小时
注册时间
2009-7-16
最后登录
2018-10-5

20论坛币
如图,求每个stkcd的所有缺省值跟连续的缺省值。
比如对于002067,总共的dcost缺省为2,07与12缺失。而连续缺省值,07年取1,12年取1,对于002066,则08,09,10的连续缺省,值是3

1.jpg (322.81 KB)

1.jpg

最佳答案

yongyitian 查看完整内容

不好意思, 第10行后加入一行 if missing(dcost) then totalMiss + 1;
关键词:缺省值 stkcd Cost cos STK 如何 统计
沙发
yongyitian 发表于 2014-8-29 16:13:28 |只看作者 |坛友微信交流群
小鳄鱼a 发表于 2014-8-31 08:48
不好意思,我试了试,totalmiss全部为0
不好意思,
第10行后加入一行
if missing(dcost) then totalMiss + 1;
已有 1 人评分论坛币 收起 理由
admin_kefu + 100 热心帮助其他会员

总评分: 论坛币 + 100   查看全部评分

使用道具

藤椅
quekehanmu 发表于 2014-8-30 09:51:00 |只看作者 |坛友微信交流群
data a;
        set 你的数据;
        where Dcost=.;
run;

proc sort data=a out=b;
        by stkcd year;
run;

data c;
        set b;
        if first.stkcd then zong_quesheng=0;
        zong_quesheng+1;
        if last.stkcd;
run;

data d;
        set b;
        lag_year=lag(year);
        if first.stkcd then lianxu_quesheng=1;
        if year=lag_year+1 then lianxu_quesheng+1;
        if last.stkcd;       
run;

data final;
        merge c d;
        by stkcd year;
run;


-----------------------
随手写来,如果报错请告知
已有 1 人评分论坛币 热心指数 收起 理由
小鳄鱼a + 5 + 3 精彩帖子

总评分: 论坛币 + 5  热心指数 + 3   查看全部评分

使用道具

板凳
小鳄鱼a 发表于 2014-8-30 10:22:55 |只看作者 |坛友微信交流群
quekehanmu 发表于 2014-8-30 09:51
data a;
        set 你的数据;
        where Dcost=.;
first.stkcd没有定义   传一份数据吧

temp.xls

1.33 MB

需要: 30 个论坛币  [购买]

使用道具

报纸
quekehanmu 发表于 2014-8-30 10:48:19 |只看作者 |坛友微信交流群
小鳄鱼a 发表于 2014-8-30 10:22
first.stkcd没有定义   传一份数据吧
你把“你的数据” 改为你导入的sas数据名就可以了

使用道具

地板
quekehanmu 发表于 2014-8-30 10:57:31 |只看作者 |坛友微信交流群
小鳄鱼a 发表于 2014-8-30 10:22
first.stkcd没有定义   传一份数据吧
data a;
        set 你的数据;
        where Dcost=.;
run;

proc sort data=a out=b;
        by stkcd year;
run;

data c;
        set b;
        by stkcd year;
        if first.stkcd then zong_quesheng=0;
        zong_quesheng+1;
        if last.stkcd;
run;

data d;
        set b;
        by stkcd year;
        lag_year=lag(year);
        if first.stkcd then lianxu_quesheng=1;
        if year=lag_year+1 then lianxu_quesheng+1;
        if last.stkcd;      
run;

data final;
        merge c d;
        by stkcd year;
run;
已有 1 人评分论坛币 热心指数 收起 理由
小鳄鱼a + 5 + 2 精彩帖子

总评分: 论坛币 + 5  热心指数 + 2   查看全部评分

使用道具

7
yongyitian 发表于 2014-8-30 11:03:53 |只看作者 |坛友微信交流群
  1. /* try this */
  2. data want;
  3.     array dvalue{9} _temporary_;
  4.      i = 1;
  5.     do until (last.stkcd);
  6.        set temp;
  7.        by stkcd;
  8.        dvalue[i] = dcost;  
  9.        i+1;
  10.     end;

  11.         flag = 0;
  12.     do i = 1 to 9;                     
  13.        if missing(dvalue[i]) then do;
  14.             if flag = 0 then do;  flag = 1; nmiss = 1;  s1 = i;  s2 = i;
  15.                             end;   
  16.        else if flag = 1 then  do; nmiss + 1; s2+1;
  17.                              end;
  18.        end;

  19.        if (^missing(dvalue[i]) and flag=1) or (i=9 and flag=1)then do;
  20.             do j = s1 to s2;
  21.                dvalue[j] =nmiss;      
  22.             end;
  23.               flag=0;
  24.         end;  
  25.     end;

  26.    i = 1;
  27.    do until (last.stkcd);
  28.       set temp;
  29.       by stkcd;
  30.       dcost= dvalue[i];
  31.       output;
  32.    i + 1;
  33.    end;
  34.    drop i j flag s1 s2 nmiss;
  35. run;
复制代码
已有 1 人评分论坛币 热心指数 收起 理由
小鳄鱼a + 5 + 1 精彩帖子

总评分: 论坛币 + 5  热心指数 + 1   查看全部评分

使用道具

8
小鳄鱼a 发表于 2014-8-30 14:36:37 |只看作者 |坛友微信交流群
yongyitian 发表于 2014-8-30 11:03
不好意思,是产生两个新的变量来分别计算dcost的总的缺失值跟连续的缺失值,而不是用连续的缺失值将dcost覆盖掉

1.jpg (272.52 KB)

1.jpg

使用道具

9
yongyitian 发表于 2014-8-30 23:08:05 |只看作者 |坛友微信交流群
小鳄鱼a 发表于 2014-8-30 14:36
不好意思,是产生两个新的变量来分别计算dcost的总的缺失值跟连续的缺失值,而不是用连续的缺失值将dcost ...
  1. data want;
  2.     array dvalue{9} _temporary_;
  3.     array cmiss{9}  _temporary_ ;
  4.     do i = 1 to 9; cmiss[i]=0; end;
  5.                i = 1;
  6.        totalMiss = 0;
  7.     do until (last.stkcd);
  8.        set temp;
  9.        by stkcd;
  10.        dvalue[i] = dcost;  
  11.        i+1;
  12.     end;

  13.         flag = 0;
  14.     do i = 1 to 9;                     
  15.        if missing(dvalue[i]) then do;
  16.             if flag = 0 then do;  flag = 1; nmiss = 1;  s1 = i;  s2 = i;
  17.                             end;   
  18.        else if flag = 1 then  do; nmiss + 1; s2+1;
  19.                              end;
  20.        end;

  21.        if (^missing(dvalue[i]) and flag=1) or (i=9 and flag=1)then do;
  22.             do j = s1 to s2;
  23.                cmiss[j] = nmiss;      
  24.             end;
  25.               flag=0;
  26.         end;  
  27.     end;

  28.    i = 1;
  29.    do until (last.stkcd);
  30.       set temp;
  31.       by stkcd;
  32.         continue_miss = cmiss[i];
  33.       output;
  34.    i + 1;
  35.    end;
  36.    drop i j flag s1 s2 nmiss;
  37. run;
复制代码
已有 1 人评分论坛币 学术水平 热心指数 收起 理由
小鳄鱼a + 5 + 2 + 2 精彩帖子

总评分: 论坛币 + 5  学术水平 + 2  热心指数 + 2   查看全部评分

使用道具

10
小鳄鱼a 发表于 2014-8-31 08:48:31 |只看作者 |坛友微信交流群
yongyitian 发表于 2014-8-30 23:08
不好意思,我试了试,totalmiss全部为0

使用道具

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

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

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

GMT+8, 2024-4-23 18:33