在循环中使用计数时出现语法错误

Syntax error when using count in loop

我正在尝试 运行 一个循环,我在变量 _merge 下计算每个文件中的总数,然后计算 _merge 的某些结果,例如 [=14] =] 等等。然后我想通过将 _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 

这是语法错误还是更严重的问题?

引用局部宏时需要使用`而不是':

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]