如何在R中合并两列?

3

我的数据框有两列,看起来类似于以下内容:

a    b

NA   NA
yes  NA
no   NA
yes  NA
NA   yes
NA   no 
NA   NA
Na   yes

What I would then like as output is:

ab

NA
yes
no
yes
yes
no
NA
yes

请注意:
  • 在原始列中,每行都会有一个NA。
  • 对于某些行,两个列都将是NA
我应该如何得到所需的输出?
5个回答

4
  • dplyr::coalesce
> with(dat, dplyr::coalesce(a, b))
[1] NA    "yes" "no"  "yes" "yes" "no"  NA    "yes"
  • 基于R语言的ifelse条件语句
> with(dat, ifelse(!is.na(a), a, ifelse(!is.na(b), b, NA)))
[1] NA    "yes" "no"  "yes" "yes" "no"  NA    "yes"
  • 基于R的max.col
> dat[cbind(1:nrow(dat), max.col(!is.na(dat)))]
[1] NA    "yes" "no"  "yes" "yes" "no"  NA    "yes"

2
使用dplyr可以很好地封装它:
library(dplyr)

df %>% rowwise() %>% summarize(ab = max(a,b, na.rm = T))

1
dat <- data.frame(a = c(NA, "yes", "no", "yes", NA, NA, NA, NA),
                  b = c(NA, NA, NA, NA, "yes", "no", NA, "yes"))

require(tidyverse)

dat %>% 
  rowwise() %>% 
  mutate(ab = max(a,b, na.rm = TRUE))

1
使用 apply:
> apply(df, 1, max, na.rm=TRUE)
[1] NA    "yes" "no"  "yes" "yes" "no"  NA    "yes"

作业:

df$ab <- apply(df, 1, max, na.rm=TRUE)

0
# Import data: df => data.frame 
df <- structure(list(a = c(NA, "yes", "no", "yes", NA, NA, NA, NA), 
b = c(NA, NA, NA, NA, "yes", "no", NA, "yes")), class = "data.frame", row.names = c(NA, 
-8L))

# Function to coalesce vectors: br_coalesce => function
br_coalesce <- function(...){
   # Coalesce vectors or data.frames: res => vector
   res <- Reduce(function(x, y) {
         x <- replace(x, is.na(x), y[is.na(x)])
      },
      list(...)
   )
   # Explicitly define returned vectors: character vector => env
   return(res)
}

# Apply function: character vector / data.frame => stdout(console)
br_coalesce(df$a, df$b)

整洁解决方案:
library(tidyverse)
df %>% 
   transmute(res = coalesce(a, b))

使用 data.table 解决方案:

library(data.table)
fcoalesce(df$a, df$b)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接