楼主: dxystata
1748 4

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

版主

已卖:302份资源

大师

37%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
183395 个
通用积分
15333.1475
学术水平
208 点
热心指数
271 点
信用等级
174 点
经验
298627 点
帖子
5586
精华
1
在线时间
13632 小时
注册时间
2006-6-21
最后登录
2025-12-22

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

楼主
dxystata 发表于 2019-9-1 12:15:46 |AI写论文
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
拉您进交流群
GMT+8, 2026-1-1 22:19