我想在Stata age_cat中创建一个基于age的新变量。我的代码:
gen age_cat = age
replace age_cat = "Adult" if age>18 | "0-5 years" if age >=0 & age<=5 | "6-11 years" if age>=6 & age<=11 | "12-18 years" if age>=12 & age<=18我得到了一个类型错配错误:
type mismatch
r(109);我该怎么解决这个问题?我知道encode将用于字符串到数字替换。有什么办法可以做到这一点吗?
发布于 2021-08-17 08:54:22
直接的错误很简单。您将age复制到age_cat,因此age_cat显然是一个数值变量,就像age一样。然后尝试使用字符串值对其进行replace。这是一个type mismatch,斯塔塔被保释了。
或者,如果age实际上是一个字符串变量,那么将它与数值(如18 )进行比较也是一个type mismatch。
您的其他语法无论如何都会失败。逻辑运算符| (或)可用于分隔输入条件。它永远不能用来区分不同的结果。
假设age是数字的,下面是您想做的事情的一种缓慢方式:
gen age_cat =  "Adult" if inrange(age, 19, .) 
replace age_cat = "12-18 years" if inrange(age, 12, 18)
replace age_cat = "6-11 years" if inrange(age, 6, 11) 
replace age_cat = "0-5 years" if inrange(age, 0, 5) 我已经添加了代码,这样的缺失年龄(超过18岁)将不会被归类为Adult。
另一种方法是:
gen age_cat = cond(age > 18, "Adult", cond(age >= 12, "12-18 years", cond(age >= 6, "6-11 years", "0-5 years))) if age < . 在这里,我已经明确地设置了一个缺失值的陷阱。cond()在各种语言中相当于ifelse()。如果需要更多细节,请参见本教程。
还有recode,它吸引了很多人。
https://stackoverflow.com/questions/68813803
复制相似问题