9

我对 gridExtra 包中的 tableGrob/grid.table 有疑问。使用常规参数设置,可以直接为交替行着色。但是,我希望对行的颜色进行更多控制可能是可行的。

例如,是否可以每隔三行用不同的颜色着色?我怀疑 grid.edit 函数是解决这个问题的一种方法,从这个链接中的例子来看:http ://code.google.com/p/gridextra/wiki/tableGrob但我不知道如何应用它我的问题。

我相信发布这个问题的人也有同样的想法。使用 tableGrob 具有不同颜色行的表格

由于兼容性问题,我目前坚持使用 R 2.13,所以如果有任何不涉及更高版本的建议,那将是理想的。

示例代码:

library(gridExtra)

grid.table(mtcars[1:10, ],
           gpar.coretext = gpar(fontsize = 10),
           gpar.corefill = gpar(fill = "lightblue", alpha=0.5, col = NA),
           h.even.alpha = 0.5
           )

示例表

4

1 回答 1

9

从 gridExtra 的 v>=2.0.0 开始,grid.table现在基于 gtable,并且可以定制到比以前版本更深的级别。小插图有更多示例,但为了完整起见,这里是一个示例,说明如何突出显示特定单元格,

g <- tableGrob(iris[1:4, 1:3])
find_cell <- function(table, row, col, name="core-fg"){
  l <- table$layout
  which(l$t==row & l$l==col & l$name==name)
}

ind <- find_cell(g, 3, 2, "core-fg")
ind2 <- find_cell(g, 2, 3, "core-bg")
g$grobs[ind][[1]][["gp"]] <- gpar(fontsize=15, fontface="bold")
g$grobs[ind2][[1]][["gp"]] <- gpar(fill="darkolivegreen1", col = "darkolivegreen4", lwd=5)
grid.draw(g)

编辑:上述功能很容易“矢量化”

find_cells <- function(table, row, col, name="core-fg"){
  l <- table$layout
  unlist(Map(function(r, c) which(((l$t-1) == r) & ((l$l-1) == c) & (l$name == name)), row, col))
}

modify_cells <- function(g, ids, gp=gpar()){
  for(id in ids) g$grobs[id][[1]][["gp"]] <- gp
  return(g)
}

ids <- find_cells(g, 1:3, c(3,2, 1), "core-fg")
g <- modify_cells(g, ids, gpar(fontsize=15, fontface="bold"))

grid.newpage()
grid.draw(g)

在此处输入图像描述

请注意,在大多数情况下,在表构建期间指定参数会更有意义,

faces <- sample(1:4, size = prod(dim(iris[1:4, 1:2])), replace = TRUE)
tt <- ttheme_default(core=list(fg_params=list(fontface=faces)))

grid.table(iris[1:4, 1:2], theme=tt)

在此处输入图像描述

于 2013-08-24T18:58:56.630 回答