楼主: dxystata
1384 4

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

版主

大师

34%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

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

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

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
沙发
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   查看全部评分

使用道具

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

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

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

GMT+8, 2024-4-26 12:07