连老师, 有一个小问题想请教您:我现在有每只股票每个季度机构投资者持股比例的数据,想计算每只股票每季度机构投资者的累积持股期限,我想count命令和by sort 命令联合完成,但是难点是累积持股期限的计算,范例数据是这样的,请连老师指教:
公司 季度 机构持股比例 累计持股期限(需要计算的变量)
股票A 2006q1 0 0
股票A 2006q2 1% 1
股票A 2006q3 2% 2
股票A 2006q4 0 0股票A 2007q1 0 0
股票A 2007q2 1% 1
股票B …… ……
您给我的建议是:
tsset id t
gen yes_hold = (hold>0)
gen aa = sum(yes_hold)
replace aa=0 if hold==0
我对程序做了一个小的修改:
xtset id t
gen yes_hold = (hold>0)
bysort id: gen aa=sum(yes_hold)
replace aa=0 if hold==0
不过,还是有一个小问题没有解决,就是例子中,如果某机构先对股票投资一段时间,之后撤资,后来再投资,那么这个时候计算投资期限时本应从1开始,但是我们现在只能计算累计值。这个小问题还请连老师点拨,数据就是这个帖子第二段红笔的那个例子