我正在尝试运行一个循环,在该循环中我计算变量_merge
下每个文件的总数,然后计算_merge
的某些结果,例如_merge=1
,依此类推。然后,我想通过将_merge
的每个实例除以_merge
下的总数来计算百分比。
下面是我的代码:
/*define local list*/
local ward_names B C D E FN FS GS HE
/*loop for each dbase*/
foreach file of local ward_names {
use "../../../cleaning/sra/output/`file'_ward_CTS_Merged.dta", clear
count if _merge
local ward_count=r(N)
count if _merge==1
local count_master=r(N)
count if _merge==2
local count_using=r(N)
count if _merge==3
local count_match=r(N)
clear
set obs 1
g ward_count='ward_count'
g count_master=`count_master'
g count_using=`count_using'
g count_match=`count_match'
g ward= "`file'"
save "../temp/`file'_collapsed_diagnostics.dta", replace
clear
代码运行良好,直到我尝试添加每个病房文件的总数:
g ward_count='ward_count'
'ward_count' invalid name
这是语法错误还是更严重的错误?
答案 0 :(得分:2)
在引用本地宏时,您需要使用`代替':
generate ward_count = `ward_count'
编辑:
根据@NickCox的建议,您可以使用带有tabulate
选项的matcell()
命令来一次获得所有计数:
tabulate _merge, matcell(A)
_merge | Freq. Percent Cum.
------------------------+-----------------------------------
master only (1) | 1 16.67 16.67
matched (3) | 5 83.33 100.00
------------------------+-----------------------------------
Total | 6 100.00
matrix list A
A[2,1]
c1
r1 1
r2 5
因此您可以执行以下操作:
generate count_master = A[1,1]
generate count_match = A[2,1]