我正在尝试使用tabulate
Stata 中的命令来创建频率的时间序列。当我尝试合并tabulate
每个日期之后的输出时,就会出现问题。tabulate
当所讨论的变量的值不存在观察值时,将不包括 0 作为条目。例如,如果我想计算一个班级中 10 岁、11 岁和 12 岁的学生,如果只代表其中一个组,Stata 可能会输出 (8),因此我们不知道 8 组是哪一组学生属于:可能是 (0,8,0) 或 (0,0,8)。
如果时间序列很短,这不是问题,因为“结果”窗口会显示哪些类别已表示或未表示。我的数据有更长的时间序列。有谁知道强制Stata在这些表格中包含零的解决方案/方法?我的代码的相关部分如下:
# delimit;
set more off;
clear;
matrix drop _all;
set mem 1200m;
cd ;
global InputFile "/Users/.../1973-2010.dta";
global OutputFile "/Users/.../results.txt";
use $InputFile;
compress;
log using "/Users/.../log.txt", append;
gen yr_mn = ym(year(datadate), month(datadate));
la var yr_mn "Year-Month Date"
xtset, clear;
xtset id datadate, monthly;
/*Converting the Ratings Scale to Numeric*/;
gen LT_num = .;
replace LT_num = 1 if splticrm=="AAA";
replace LT_num = 2 if (splticrm=="AA"||splticrm=="AA+"||splticrm=="AA-");
replace LT_num = 3 if (splticrm=="A"||splticrm=="A+"||splticrm=="A-");
replace LT_num = 4 if (splticrm=="BBB"||splticrm=="BBB+"||splticrm=="BBB-");
replace LT_num = 5 if (splticrm=="BB"||splticrm=="BB+"||splticrm=="BB-");
replace LT_num = 6 if (splticrm=="B"||splticrm=="B+"||splticrm=="B-");
replace LT_num = 7 if (splticrm=="CCC"||splticrm=="CCC+"||splticrm=="CCC-");
replace LT_num = 8 if (splticrm=="CC");
replace LT_num = 9 if (splticrm=="SD");
replace LT_num = 10 if (splticrm=="D");
summarize(yr_mn);
local start = r(min);
local finish = r(max);
forv x = `start'/`finish' {;
qui tab LT_num if yr_mn == `x', matcell(freq_`x');
};
log close;