我想将相关表排列成行。
var1 var2 var3 var4
var1 1 x x x
var2 x 1 x x
var3 x x 1 x
var4 x x x 1
var1 var2 x
var1 var3 x
var1 var4 x
var2 var3 x
var2 var4 x
var3 var4 x
您可以将行名作为单独的列获取,以长格式获取数据,然后删除其中包含1的行。
library(magrittr)
df1 <- df %>%
tibble::rownames_to_column('rows') %>%
tidyr::pivot_longer(cols = -rows, names_to = 'cols') %>%
dplyr::filter(value != 1)
df1
# A tibble: 12 x 3
# rows cols value
# <chr> <chr> <chr>
# 1 var1 var2 x
# 2 var1 var3 x
# 3 var1 var4 x
# 4 var2 var1 x
# 5 var2 var3 x
# 6 var2 var4 x
# 7 var3 var1 x
# 8 var3 var2 x
# 9 var3 var4 x
#10 var4 var1 x
#11 var4 var2 x
#12 var4 var3 x
要将其编写为csv,我们可以这样做:
write.csv(df1, 'data.csv', row.names = FALSE)
数据
df <- structure(list(var1 = c("1", "x", "x", "x"), var2 = c("x", "1",
"x", "x"), var3 = c("x", "x", "1", "x"), var4 = c("x", "x", "x",
"1")), class = "data.frame", row.names = c("var1", "var2", "var3","var4"))