gpt4 book ai didi

r - 如何调整使用 R kableExtra::add_header_above 创建的表中的标签?

转载 作者:行者123 更新时间:2023-12-03 01:13:56 24 4
gpt4 key购买 nike

我如何(或者可以)调整使用 kableExtra::add_header_above() 创建的表中的标签?一个小例子:

library(knitr)
library(dplyr)
library(tidyr)
library(kableExtra)

df <- tibble(year = c(2017, 2018, 2017, 2018),
major_item = "M",
sub_item = c( "A", "A", "B", "B"),
n = c( 1:4))
df %>%
filter(sub_item == "A") %>%
select(-sub_item) %>%
spread(year,n) %>%
# now join with the part for which sub_item == "B"
left_join(df %>%
filter(sub_item == "B") %>%
select(-sub_item) %>%
spread(year,n),
by = c("major_item" = "major_item")) %>%
# now the nice header
kable("latex", booktabs = T) %>%
kable_styling() %>%
add_header_above(c(" " = 1, "A" = 2, "B" = 2))

结果是:

enter image description here

当然,出现后缀.x是因为存在同名的列,这是一组中不允许的。我该怎么做才能使 2017.x 和 2018.x 与其他列 2017 和 2018 相同?任何关于如何以更少的步骤获得结果表的提示也非常受欢迎。谢谢!

更新2019_09_26:感谢pivot_wider,我找到了一种优雅的方式来构造表,并且感谢iago,它具有所需的列名称:

df %>%
# the table structure
pivot_wider(names_from = c(year, sub_item),
values_from = n) %>%
# the nice headings
kable("latex", booktabs = T,
col.names = c("", "2017", "2018", "2017", "2018")) %>%
kable_styling() %>%
add_header_above(c(" " = 1, "A" = 2, "B" = 2))

最佳答案

我会这样做:

library(knitr)
library(dplyr)
library(tidyr)
library(kableExtra)

df <- tibble(year = c(2017, 2018, 2017, 2018),
major_item = "M",
sub_item = c( "A", "A", "B", "B"),
n = c( 1:4))

df %>%
filter(sub_item == "A") %>%
select(-sub_item) %>%
spread(year,n) %>%
# now join with the part for which sub_item == "B"
left_join(df %>%
filter(sub_item == "B") %>%
select(-sub_item) %>%
spread(year,n),
by = c("major_item" = "major_item")) %>%
# now the nice header
kable("latex", booktabs = T, col.names = c("major_item","2017","2018","2017","2018")) %>%
kable_styling() %>%
add_header_above(c(" " = 1, "A" = 2, "B" = 2))

关于r - 如何调整使用 R kableExtra::add_header_above 创建的表中的标签?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58062088/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com