stata分组生成新变量

img


如图,按ID对数据进行分类,生成新变量time1,取值为time=1时的age值,以此类推生成time2,time3等,最后生成这张图

img


如何通过stata实现呢

以下内容部分参考ChatGPT模型:


可以使用Stata的egen命令来实现按ID对数据进行分类,并生成新变量。具体操作如下:

  1. 用sort命令按ID排序:
sort ID
  1. 用egen命令生成新变量time1,取值为time=1时的age值:
egen time1 = mean(cond(time==1, age, .)), by(ID)
  1. 以此类推生成time2,time3等:
egen time2 = mean(cond(time==2, age, .)), by(ID)
egen time3 = mean(cond(time==3, age, .)), by(ID)
  1. 用graph命令生成图表:
graph twoway (scatter time1 ID) (scatter time2 ID) (scatter time3 ID)

完整代码如下:

sort ID
egen time1 = mean(cond(time==1, age, .)), by(ID)
egen time2 = mean(cond(time==2, age, .)), by(ID)
egen time3 = mean(cond(time==3, age, .)), by(ID)
graph twoway (scatter time1 ID) (scatter time2 ID) (scatter time3 ID)

如果我的建议对您有帮助、请点击采纳、祝您生活愉快