楼主: dxystata
160 4

[问答] 如何在x取值为0这一行上添加一行空行 [推广有奖]

版主

学术权威

91%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
160359 个
通用积分
13269.7454
学术水平
198 点
热心指数
252 点
信用等级
163 点
经验
218308 点
帖子
3923
精华
1
在线时间
10100 小时
注册时间
2006-6-21
最后登录
2019-9-20

初级学术勋章 初级热心勋章

dxystata 发表于 2019-9-1 12:15:46 |显示全部楼层
10论坛币
  1. data aaa;
  2. input x;
  3. cards;
  4. 0
  5. 1
  6. 1
  7. 0
  8. 1
  9. 1
  10. 1
  11. 0
  12. 1
  13. 1
  14. ;
  15. run;
复制代码
如何在x取值为0的这一行上添加一行空行,不包括首行。得到的数据集如下:
0
1
1
.
0
1
1
1
.     
0
1
1


最佳答案

l1i2n3i4n5g 查看完整内容

data want; set aaa; if _n_=1 then output; else if x=0 then do; x=.;output; x=0;output; end; else output; run;
关键词:cards Input Data card Run
stata SPSS
l1i2n3i4n5g 在职认证  发表于 2019-9-1 12:15:47 |显示全部楼层
data want;
   set aaa;
   if _n_=1 then output;
   else if x=0 then do;
      x=.;output;
      x=0;output;
   end;
   else output;
run;
已有 2 人评分经验 学术水平 热心指数 信用等级 收起 理由
dxystata + 100 + 2 + 2 + 2 精彩帖子
gudingji + 1 + 1 + 1 精彩帖子

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

回复

使用道具 举报

lovexialulu 发表于 2019-9-2 11:36:59 |显示全部楼层
  1. data b;
  2.    set aaa;
  3.    id = _n_;
  4. run;

  5. data c;
  6.    set b(where=(x eq 0));
  7.    x = .;
  8.    if id eq 1 and x eq . then
  9.       delete;
  10. run;

  11. data d;
  12.    set b c;
  13. proc sort;by id x;
  14. run;
复制代码
已有 2 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
dxystata + 100 + 2 + 2 + 2 精彩帖子
祝贺人大 + 80 + 5 + 3 热心帮助其他会员

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

回复

使用道具 举报

dxystata 发表于 2019-9-8 01:46:02 |显示全部楼层
l1i2n3i4n5g 发表于 2019-9-3 16:40
data want;
   set aaa;
   if _n_=1 then output;
  1. data aaa;
  2. input x x1$ x2$ y;
  3. cards;
  4. 0 a b 1
  5. 1 c d 1
  6. 1 a a 1
  7. 0 b b 2
  8. 1 c c 2
  9. 1 c c 2
  10. 1 c d 2
  11. 0 a c 1
  12. 1 a d 1
  13. 1 b c 1
  14. ;
  15. run;
复制代码
如果x后有很多变量,这些变量如何也变成缺失。
回复

使用道具 举报

l1i2n3i4n5g 在职认证  发表于 2019-9-9 11:14:54 |显示全部楼层
dxystata 发表于 2019-9-8 01:46
如果x后有很多变量,这些变量如何也变成缺失。
data want;
   do i=1 to nobs;
      set aaa point=i nobs=nobs;
      if i=1 then output;
      else if x=0 then do;
         call missing(of _all_);output;
         set aaa point=i;output;
      end;
      else output;
   end;
   stop;
run;
已有 2 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
whymath + 5 + 1 + 1 精彩帖子
dxystata + 100 + 2 + 2 + 2 热心帮助其他会员

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

回复

使用道具 举报

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

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

GMT+8, 2019-9-20 22:50