r - 使用 kableExtra 将分组变量与剥离/着色匹配
问题描述
我有一个表,每个人都有多个记录ID1
(寻找解决方案。虽然这里显示了许多有用的提示,但我一直无法找到解决方案。kable_styling(c("striped"))
ID1
group_by(ID1)
我还想知道如何为表格制作单个外部边框,而不是为每个单元格设置边框。
下面是一个可重现的数据集。
提前谢谢了。
```{r echo=F, warning=F, message = FALSE}
library(tidyverse)
library(kableExtra)
set.seed(121)
Dat <- data.frame(
ID1 = sample(c("AAA", "BBB", "CCC","DDD"), 100, replace = T),
ID2 = sample(c("Cat", "Dog", "Bird"), 100, replace = T),
First = rnorm(100),
Two = sample.int(100))
ExTbl <- Dat %>%
group_by(ID1, ID2) %>%
summarize(One = mean(First),
Max = max(Two)) %>%
arrange(ID1)
kable(ExTbl) %>%
kable_styling(c("striped", "bordered"), full_width = F)
```
> head(as.data.frame(ExTbl) )
ID1 ID2 One Max
1 AAA Bird 0.15324169 86
2 AAA Cat -0.02726006 83
3 AAA Dog -0.19618126 78
4 BBB Bird 0.62176633 100
5 BBB Cat -0.35502912 77
6 BBB Dog -0.29977145 87
>
解决方案
目前在 kableExtra 中没有直接的方法,但这是我上次使用的方法。也许我应该把它装进这个包里。
library(tidyverse)
library(kableExtra)
set.seed(121)
Dat <- data.frame(
ID1 = sample(c("AAA", "BBB", "CCC","DDD"), 100, replace = T),
ID2 = sample(c("Cat", "Dog", "Bird"), 100, replace = T),
First = rnorm(100),
Two = sample.int(100))
ExTbl <- Dat %>%
group_by(ID1, ID2) %>%
summarize(One = mean(First),
Max = max(Two)) %>%
arrange(ID1)
ind_end <- cumsum(rle(as.character(ExTbl$ID1))$lengths)
ind_start <- c(1, ind_end[-length(ind_end)] + 1)
pos <- purrr::map2(ind_start, ind_end, seq)
pos <- unlist(pos[1:length(pos) %% 2 != 0])
kable(ExTbl) %>%
kable_styling(c("bordered"), full_width = F) %>%
row_spec(pos, background = "#EEEEEE")
推荐阅读
- php - 刷新后页面选择下拉菜单被清除
- javascript - 如何在 ionic 3+ 中更改单个页面的背景颜色
- javascript - 使用 ng-view 时 AngularJS 数组不更新
- c++ - 如何在 OpenGL 中创建调试标记?
- ruby-on-rails - ParameterMissing 错误:在 ruby on rails 中更新记录?
- database - 参数的类型必须是带有@Entity 注释的类或它的集合/数组。/ 在转换 ArrayList 时
- python - 如何避免 Pygame 将女声变成男声
- python - 敌人不会显示
- android - 从回收站视图中删除多个(50 多个)项目会引发异常(附加 Stacktrace)
- node.js - 调用函数不断给我一个承诺而不是一个对象