全部版块 我的主页
论坛 计量经济学与统计论坛 五区 计量经济学与统计软件 Stata专版
7458 3
2018-02-28
悬赏 20 个论坛币 未解决
变量名为code_1, code_2, code_3, ..., code_6, code, base;其中code的取值范围是1到10,我想把base和code_n的值连起来,n值为同一行code的取值。比如说:
code_1 code_2 code_3 code_4 code_5 code_6  code base
1              2          3             4          5          6          3      56
2              4          2             2          2          9          1        2

想生成一个新变量base_code,它的值为
base_code
59 (base+code_3)
4 (base+code_1)

自己是用python的,可以用locals来动态生成变量从而提取数值,stata不知道怎么做?

刚学stata,有很多不懂,希望大神解答,谢谢!

二维码

扫码加我 拉你入群

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

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

全部回复
2018-2-28 14:41:55
搞出来了,自己过来答一波:
gen tmp=.
forvalues i=1/_N{
local v=code[`i']
replace tmp=code_[`v'] if _n==`i'
}
不过感觉这样的代码有些丑,应该会有更优解,所以还是希望有大神能解决一下。
二维码

扫码加我 拉你入群

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

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

2018-2-28 17:10:49
尔后建议请用 dataex (先 ssc install dataex 并见说明) 将原始 Stata 资料中具有”代表性”的一部分资料列出,以供有意回答者实验之用,并能提供具体操作指令。并请参考 http://www.jianshu.com/p/9870080fe769,  https://bbs.pinggu.org/thread-5048204-1-1.html, 与 https://bbs.pinggu.org/thread-5917273-1-1.html
二维码

扫码加我 拉你入群

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

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

2018-2-28 20:05:29
谢谢建议。数据如下:
input code_1 code_2 code_3 code_4 code_5 code_6  code base
1 2 3 4 5 6 3 56
2 4 2 2 2 9 1 2
end
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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