首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >替换类型不匹配(数字到字符串)

替换类型不匹配(数字到字符串)
EN

Stack Overflow用户
提问于 2021-08-17 08:08:46
回答 1查看 858关注 0票数 1

我想在Stata age_cat中创建一个基于age的新变量。我的代码:

代码语言:javascript
运行
复制
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

我得到了一个类型错配错误:

代码语言:javascript
运行
复制
type mismatch
r(109);

我该怎么解决这个问题?我知道encode将用于字符串到数字替换。有什么办法可以做到这一点吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-17 08:54:22

直接的错误很简单。您将age复制到age_cat,因此age_cat显然是一个数值变量,就像age一样。然后尝试使用字符串值对其进行replace。这是一个type mismatch,斯塔塔被保释了。

或者,如果age实际上是一个字符串变量,那么将它与数值(如18 )进行比较也是一个type mismatch

您的其他语法无论如何都会失败。逻辑运算符| (或)可用于分隔输入条件。它永远不能用来区分不同的结果。

假设age是数字的,下面是您想做的事情的一种缓慢方式:

代码语言:javascript
运行
复制
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

另一种方法是:

代码语言:javascript
运行
复制
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,它吸引了很多人。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68813803

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档