首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在R中将文本观测值转换为1 1或0 0?

如何在R中将文本观测值转换为1 1或0 0?
EN

Stack Overflow用户
提问于 2021-08-11 23:39:11
回答 3查看 227关注 0票数 1

我有一个数据集,其中包含一些候选人的教育履历信息。例如,我有一个专栏,其中PhD学位的人必须包括他们的领域(如果适用的话),或者NA,如果没有。像这样

代码语言:javascript
复制
Participants   PHD_Field
A              Economics
B              Sciences
C              NA
D              NA
E              NA

我需要创建一个列,并将它们的字段转换为1,并将N/As转换为0。你能帮我用密码在R里做这个吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-08-12 00:29:52

代码语言:javascript
复制
df$phd <- as.integer(!is.na(df$PHD_Field))

过程分解:

代码语言:javascript
复制
is.na(df$PHD_Field) # is.na = is the value NA?

1假假真真

代码语言:javascript
复制
!is.na(df$PHD_Field) # adding a ! (NOT) to reverse the logic; is the value NOT NA

1真假假假

代码语言:javascript
复制
as.integer(!is.na(df$PHD_Field)) # as.integer = turn F into 0, and T into 1

1 1 1 0 0

代码语言:javascript
复制
df$phd <- as.integer(!is.na(df$PHD_Field)) # assign to the dataframe field phd
df
  Participants PHD_Field phd
1            A Economics   1
2            B  Sciences   1
3            C      <NA>   0
4            D      <NA>   0
5            E      <NA>   0
票数 0
EN

Stack Overflow用户

发布于 2021-08-11 23:54:59

代码语言:javascript
复制
library(tidyverse)

df1 <- data.frame(
  stringsAsFactors = FALSE,
  Participants = c("A", "B", "C", "D", "E"),
  PHD_Field = c("Economics", "Sciences", NA, NA, NA)
)
df1 %>%
  mutate(phd = as.integer(!is.na(PHD_Field)))
#>   Participants PHD_Field phd
#> 1            A Economics   1
#> 2            B  Sciences   1
#> 3            C      <NA>   0
#> 4            D      <NA>   0
#> 5            E      <NA>   0
票数 1
EN

Stack Overflow用户

发布于 2021-08-12 00:04:56

下面是使用ifelse的基本R解决方案

代码语言:javascript
复制
df$phd <- ifelse(is.na(df$PHD_Field), 0, 1)

输出:

代码语言:javascript
复制
  Participants PHD_Field   phd
  <chr>        <chr>     <dbl>
1 A            Economics     1
2 B            Sciences      1
3 C            NA            0
4 D            NA            0
5 E            NA            0
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68750042

复制
相关文章

相似问题

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