楼主: yunxiangcao
12988 15

[原创博文] SAS程序如何实现在满足条件下重复拷贝上一行数据? [推广有奖]

  • 0关注
  • 1粉丝

已卖:311份资源

硕士生

35%

还不是VIP/贵宾

-

威望
0
论坛币
875 个
通用积分
3.4018
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
2245 点
帖子
88
精华
0
在线时间
163 小时
注册时间
2005-10-29
最后登录
2025-4-11

楼主
yunxiangcao 发表于 2010-9-19 11:03:02 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
请教一个问题,如何在满足条件下重复拷贝上一行数据?请给出SAS程序语句

以下是数据集A中的数据格式:
Stkcd    Trddt             Nshrttl        SASDate
000002 1993-05-28  183546916  12201
000002 1993-05-31   .                   .
000002 1993-06-01   .                   .  
000002 1993-06-02   .                   .  
000002 1993-06-03   242955336  12207  
000002 1993-06-04   .                   .  

我想要完成的处理是:如果某一行SASDate缺失,那么该行对应的变量Nshrttl观测值为上一行观测值,即最终变成:

Stkcd    Trddt            Nshrttl         SASDate
000002 1993-05-28  183546916   12201
000002 1993-05-31  183546916    .
000002 1993-06-01  183546916    .  
000002 1993-06-02  183546916    .  
000002 1993-06-03   242955336  12207  
000002 1993-06-04   242955336   .  

SAS程序应该怎么写呢?想了很久了。谢谢啊!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:sas程序 如何实现 stkcd date 数据格式 程序 如何

回帖推荐

soporaeternus 发表于2楼  查看完整内容

感觉有点繁琐,一下子又想不出别的方法......

本帖被以下文库推荐

沙发
soporaeternus 发表于 2010-9-19 11:23:58
  1. data b(rename=(s=Nshrttl));
  2.         retain Stkcd Trddt s SASDate;
  3.         set a;
  4.         if SASDate^=. then s=Nshrttl;
  5.         drop Nshrttl;
  6. run;
复制代码
感觉有点繁琐,一下子又想不出别的方法......
已有 1 人评分论坛币 学术水平 热心指数 收起 理由
condor_gz + 4 + 1 + 1 精彩帖子

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

Let them be hard, but never unjust

藤椅
chouxiangdaishu 发表于 2010-9-20 00:13:58
  1. data b;
  2. set a;
  3. if SASDate^=. then s=Nshrttl;
  4.   retain s;
  5. Nshrttl=s;
  6. drop s;
  7. run;
复制代码

板凳
chouxiangdaishu 发表于 2010-9-20 00:14:51
2# soporaeternus

如何插入如此漂亮的代码啊?

报纸
crackman 发表于 2010-9-20 00:17:07
看我的博客 专门讲过这个问题

地板
chouxiangdaishu 发表于 2010-9-20 00:20:45
你的哪个一个博客,有写如何贴代码的?给个链接啊

7
soporaeternus 发表于 2010-9-20 09:06:26
回复中 “<>”按键......

同求那个和SAS编辑器一样的效果......
Let them be hard, but never unjust

8
chouxiangdaishu 发表于 2010-9-20 10:22:17
7# soporaeternus

got it!

9
yunxiangcao 发表于 2010-9-22 21:14:16
多谢楼上的,问题已经解决了

10
carol1222 发表于 2013-11-13 11:50:51
soporaeternus 发表于 2010-9-19 11:23
感觉有点繁琐,一下子又想不出别的方法......
没有看到这句
if SASDate ^=. then s=Nshrttl;
这是怎么样的逻辑啊???对于s来说??
花有再开日 人无再少年

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-31 19:27