楼主: benny10
1573 5

请问一下,sas 有办法计算"跨期"的数值吗? [推广有奖]

  • 0关注
  • 0粉丝

硕士生

4%

还不是VIP/贵宾

-

威望
0
论坛币
114 个
通用积分
0
学术水平
0 点
热心指数
1 点
信用等级
0 点
经验
2230 点
帖子
99
精华
0
在线时间
67 小时
注册时间
2007-6-23
最后登录
2020-3-25

楼主
benny10 发表于 2010-2-25 22:48:45 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
请问一下,sas 有办法计算"跨期"的数值吗?若我的数据如下:
1 2 3
4 5 6
7 8 9
;
要如何将第二排的5来减第一排的2这个值呢,有办法这样写吗?
二维码

扫码加我 拉你入群

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

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

关键词:SAS 办法 数值

回帖推荐

gzjb 发表于4楼  查看完整内容

data tmp; input x y z; tpy=lag(y); datalines; 1 2 3 4 5 6 7 8 9 ; data diffData(keep=x y z); set tmp; if _N_ >1 then y=y-tpy; run; proc print noobs; run; ***output**; x y z 1 2 3 4 3 6 ...

本帖被以下文库推荐

沙发
windlove 发表于 2010-2-26 06:23:29
using the function of "lag" to create a new column

original   lag(original)
2                  
5                     2
8                     5

藤椅
bobguy 发表于 2010-2-26 07:37:35
benny10 发表于 2010-2-25 22:48
请问一下,sas 有办法计算跨期的数值吗?若我的数据如下:
1 2 3
4 5 6
7 8 9
;
要如何将第二排的5来减第一排的2这个值呢,有办法这样写吗?
Do you want to the result in the first row or the second row?

板凳
gzjb 发表于 2010-2-26 09:55:49
data tmp;
input x y z;
tpy=lag(y);
datalines;
1 2 3
4 5 6
7 8 9
;

data diffData(keep=x y z);
set tmp;
if _N_ >1 then y=y-tpy;
run;

proc print noobs; run;

***output**;
                                          x    y    z

                                            1    2    3
                                            4    3    6
                                            7    3    9
已有 1 人评分经验 论坛币 收起 理由
bakoll + 3 + 3 精彩帖子

总评分: 经验 + 3  论坛币 + 3   查看全部评分

报纸
benny10 发表于 2010-2-28 21:15:32
非常感谢大家的帮忙,我会试试看,若有问题会再向大家请教的!!

地板
醉_清风 发表于 2010-3-1 12:06:10
进来学习了
但我同事说 lag 使用时容易出问题 所以要小心使用 呵呵
从来不需要想起 永远也不会忘记

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-2-18 06:09