全部版块 我的主页
论坛 计量经济学与统计论坛 五区 计量经济学与统计软件 Stata专版
2545 3
2013-06-30
想要为660个测试公司找到最接近的660个一比一控制样本。控制条件为年份year,行业industry,和ROA。要找到最就近的ROA值的公司。应该要用滚动的去配对,并且要把配对样本另外储存或者用一个新变量做标记。
二维码

扫码加我 拉你入群

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

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

全部回复
2013-7-13 14:01:37
method1: check the joinby in Stata
use sample.dta, clear
ren roa roa_sample
merge 1:m year industry using match.dta, unmatched(master)
gen diff = abs(roa_sample - roa)
gsort year industry diff
by year industry: keep if _n == 1

Method2
use sample, clear
gen id = _n
local record = `c(N)'
forvalue i = 1 / `record' {
use sample, clear
keep if id == `i'
local a = year[1]
local b = industry[1]
local c = roa[1]

use match, clear
keep if year = `a'
keep if industry = `b'
gen diff = abs( roa - `c')
sort diff
keep if _n == 1
gen id = `i'
tempfile f`i'
save `f`i''
}

use `f1', clear
forvalue i = 2  / `record' {
append using `f`i''



二维码

扫码加我 拉你入群

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

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

2013-7-13 15:01:28
占座
二维码

扫码加我 拉你入群

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

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

2013-7-28 22:43:38
ctx5518 发表于 2013-7-13 14:01
method1: check the joinby in Stata
use sample.dta, clear
ren roa roa_sample
谢谢哈,我之前找了一个例子改了一下
你的这个没试过,但看起来应该是可信的
谢谢你的回复哦
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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