全部版块 我的主页
论坛 计量经济学与统计论坛 五区 计量经济学与统计软件 Stata专版
1124 3
2015-10-16
a
1.2
3
0
0
0
0
3.1
6
1
0
0
0
0
0
3
0
0
0
上面是数据,我要做的就是相邻的非零的数求和,如果相邻的两个数都是非零就两个数求和,如果相邻的三个数都是非零就三个数求和,对于求和结果,如果大于4就保留如果小于就舍弃。求教大神应该怎么做?
二维码

扫码加我 拉你入群

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

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

全部回复
2015-10-16 22:41:28
gen result=a+a[_n-1] if a!=0&a[_n-1]!=0 in 2/l
replace result=result[_n-1]+a if result[_n-1]!=0&a!=0&result[_n-1]!=.&a!=.
replace result=. if result<4
二维码

扫码加我 拉你入群

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

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

2015-10-17 10:56:12
夏目贵志 发表于 2015-10-16 22:41
gen result=a+a[_n-1] if a!=0&var[_n-1]!=0 in 2/l
replace result=result[_n-1]+a if result[_n-1]!=0&a ...
谢谢大神~~~
我用了这个程序试了一下,第一行的var[n-1]改成a[n-1]就可以运算了~~ 然后运算结果是这样的:
a        result
0       
0       
0       
0       
0       
0       
0       
1       
4        5
5        10
0       
0       
0       
7       
6        13
3        16

0       
0       
上面有三个数的地方,只需要三个数的加总值就可以了,前面两个数的和就可删掉,这个要怎么解决啊?
二维码

扫码加我 拉你入群

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

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

2015-10-17 11:53:02
replace result=. if result[_n+1]!=.
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群