这是一个想法。我们可以拆分列,Histroy
然后创建列以将数据绘制为热图。rowid
ID
library(tidyverse)
testdata2 <- testdata %>% mutate(History = str_split(History, pattern = ""))
testdata3 <- testdata2%>%
rowid_to_column() %>%
unnest() %>%
group_by(rowid) %>%
mutate(ID =row_number())
p <- ggplot(testdata3, aes(x = ID, y = rowid, fill = History)) +
geom_tile(color = "black") +
scale_fill_brewer() +
scale_y_reverse() +
labs(x = "", y = "") +
theme_minimal()
print(p)

如果我们想在列中将数据绘制为分面TRUE
,我们需要分别创建as和for 。FALSE
Survival
rowid
TRUE
FALSE
Survival
testdata4 <- testdata2%>%
group_by(Survive) %>%
mutate(rowid = row_number()) %>%
unnest() %>%
group_by(Survive, rowid) %>%
mutate(ID = row_number())
p2 <- ggplot(testdata4, aes(x = ID, y = rowid, fill = History)) +
geom_tile(color = "black") +
scale_fill_brewer() +
scale_y_reverse() +
labs(x = "", y = "") +
theme_minimal() +
facet_grid(~ Survive)
print(p2)

数据
testdata <- read.table(text =
" History Survive
1 111111111111111211111111111111111111 FALSE
2 111111111111111110000000000000000000 TRUE
3 000111222111111111111111111111110000 FALSE
4 111111111111111111111111100000000000 TRUE
5 011231111111111111111111111111111111 FALSE
6 111111234111111111111111110000000000 TRUE",
header = TRUE, stringsAsFactors = FALSE,
colClasses = c("numeric", "character", "logical"))