1

Here is my example:

library(dplyr)
my_df <- data.frame( col_1 = I(list(c(1,2), 1 )), col_2 = c(1,2))
my_df <- my_df %>% rowwise(diff = setdiff(col_1, col_2))

It generates an error:

Error in rowwise(., diff = setdiff(col_1, col_2)) : 
  unused argument (diff = setdiff(col_1, col_2))

What is wrong and how to fix it? Any thoughts?

Update: my bad, I simply forgot to add mutate

my_df <- data.frame( col_1 = I(list(c(1,2), 1 )), col_2 = c(1,2))
my_df <- my_df %>% rowwise() %>% mutate(diff = setdiff(col_1, col_2))
user1700890
  • 7,144
  • 18
  • 87
  • 183

1 Answers1

1

An option is map2 as both columns are list

library(dplyr)
library(purrr)
my_df %>%
     mutate(diff = map2(col_1, col_2, setdiff))

Or if we need to use rowwise

my_df %>%
    rowwise %>% 
    mutate(diff = setdiff(col_1, col_2))
akrun
  • 874,273
  • 37
  • 540
  • 662