Условная окраска ячеек в таблице
Я пытаюсь создать таблицу данных, ячейки которой имеют разные цвета, основанные на значении в ячейке. Я могу добиться этого с помощью функции addtable2plot
из пакета plotrix
. Функция addtable2plot
кладет таблицу на уже существующий график. Проблема с этим решением заключается в том, что мне не нужен сюжет, только таблица.
Я также рассмотрел функции heatmap
. Проблема в том, что некоторые из значений в моей таблице являются символами, а функции heatmap
, из того, что я могу сказать, принимают только числовые матрицы. Кроме того, я хочу, чтобы имена столбцов находились в верхней части таблицы, а не внизу, и это не похоже на вариант.
Вот пример кода для addtable2plot
. Если бы я мог получить только таблицу, заполнив весь экран, это было бы здорово.
library(plotrix)
testdf<-data.frame(Before=c(10,7,5,9),During=c(8,6,2,5),After=c(5,3,4,3))
rownames(testdf)<-c("Red","Green","Blue","Lightblue")
barp(testdf,main="Test addtable2plot",ylab="Value",
names.arg=colnames(testdf),col=2:5)
# show most of the options including the christmas tree colors
abg<-matrix(c(2,3,5,6,7,8),nrow=4,ncol=3)
addtable2plot(2,8,testdf,bty="o",display.rownames=TRUE,hlines=TRUE,
vlines=TRUE,title="The table",bg=abg)
Любая помощь будет принята с благодарностью.
Ответы
Ответ 1
A heatmap
альтернатива:
library(gplots)
# need data as matrix
mm <- as.matrix(testdf, ncol = 3)
heatmap.2(x = mm, Rowv = FALSE, Colv = FALSE, dendrogram = "none",
cellnote = mm, notecol = "black", notecex = 2,
trace = "none", key = FALSE, margins = c(7, 11))
В heatmap.2
сторона графика axis
должна быть нарисована жестко. Но если вы наберете "heatmap.2
" на консоли и скопируете вывод в редактор, вы можете выполнить поиск axis(1
, где 1 является аргументом side
(два раза). Затем вы можете перейти от 1 (ось ниже графика) к 3 (ось над графиком). Назначьте обновленную функцию новому имени, например. heatmap.3, и запустите его, как указано выше.
![enter image description here]()
Альтернатива addtable2plot
library(plotrix)
# while plotrix is loaded anyway:
# set colors with color.scale
# need data as matrix*
mm <- as.matrix(testdf, ncol = 3)
cols <- color.scale(mm, extremes = c("red", "yellow"))
par(mar = c(0.5, 1, 2, 0.5))
# create empty plot
plot(1:10, axes = FALSE, xlab = "", ylab = "", type = "n")
# add table
addtable2plot(x = 1, y = 1, table = testdf,
bty = "o", display.rownames = TRUE,
hlines = TRUE, vlines = TRUE,
bg = cols,
xjust = 2, yjust = 1, cex = 3)
# *According to `?color.scale`, `x` can be a data frame.
# However, when I tried with `testdf`, I got "Error in `[.data.frame`(x, segindex) : undefined columns selected".
![enter image description here]()
A color2D.matplot
альтернативный
library(plotrix)
par(mar = c(0.5, 8, 3.5, 0.5))
color2D.matplot(testdf,
show.values = TRUE,
axes = FALSE,
xlab = "",
ylab = "",
vcex = 2,
vcol = "black",
extremes = c("red", "yellow"))
axis(3, at = seq_len(ncol(testdf)) - 0.5,
labels = names(testdf), tick = FALSE, cex.axis = 2)
axis(2, at = seq_len(nrow(testdf)) -0.5,
labels = rev(rownames(testdf)), tick = FALSE, las = 1, cex.axis = 2)
![enter image description here]()
После этого небольшого упражнения я склонен согласиться с @Drew Steen, что альтернативы LaTeX также могут быть исследованы. Например, здесь и здесь.
Ответ 2
Вы можете взломать что-то с сеткой и gtable,
palette(c(RColorBrewer::brewer.pal(8, "Pastel1"),
RColorBrewer::brewer.pal(8, "Pastel2")))
library(gtable)
gtable_add_grobs <- gtable_add_grob # alias
d <- head(iris, 3)
nc <- ncol(d)
nr <- nrow(d)
extended_matrix <- cbind(c("", rownames(d)), rbind(colnames(d), as.matrix(d)))
## text for each cell
all_grobs <- matrix(lapply(extended_matrix, textGrob), ncol=ncol(d) + 1)
## define the fill background of cells
fill <- lapply(seq_len(nc*nr), function(ii)
rectGrob(gp=gpar(fill=ii)))
## some calculations of cell sizes
row_heights <- function(m){
do.call(unit.c, apply(m, 1, function(l)
max(do.call(unit.c, lapply(l, grobHeight)))))
}
col_widths <- function(m){
do.call(unit.c, apply(m, 2, function(l)
max(do.call(unit.c, lapply(l, grobWidth)))))
}
## place labels in a gtable
g <- gtable_matrix("table", grobs=all_grobs,
widths=col_widths(all_grobs) + unit(4,"mm"),
heights=row_heights(all_grobs) + unit(4,"mm"))
## add the background
g <- gtable_add_grobs(g, fill, t=rep(seq(2, nr+1), each=nc),
l=rep(seq(2, nc+1), nr), z=0,name="fill")
## draw
grid.newpage()
grid.draw(g)
![enter image description here]()
Ответ 3
Вид хакерского решения на основе ggplot2
. Я не совсем понимаю, как вы на самом деле хотите отображать свои цвета, поскольку в вашем примере цвета в таблице не сопоставляются с именами ростов в testdf
, но здесь я сопоставил цвета с value
(преобразованный на коэффициент).
testdf$color <- rownames(testdf)
dfm <- melt(testdf, id.vars="color")
p <- ggplot(dfm, aes(x=variable, y=color, label=value, fill=as.factor(value))) +
geom_text(colour="black") +
geom_tile(alpha=0.2)
p
Вы можете изменить, какую переменную сопоставляют значения, используя fill=
, и вы можете изменить отображение с помощью scale_fill_manual(values=[a vector of values]
.
Тем не менее, мне было бы интересно увидеть решение, которое создает фактическую таблицу, а не сюжет, маскирующийся как таблица. Возможно использование таблиц Sweave и LaTeX?
![enter image description here]()