可伸缩对象第一列中的缩进
Indentation in the first column of a flextable object
我正在构建 flextable
对象来显示表格,有时我想在第一列中添加一个或多个缩进,我在其中显示一些行的名称。
接下来我分享一些代码来模拟一些数据并有一个可重现的例子。我的问题的真正起点是 ft
(Table 1):
library(dplyr)
library(flextable)
# Simulate data
g_A <- expand.grid(x = "A", y = c("A_1", "A_2"), z = c("A_1_a", "A_1_b", "A_2_a", "A_2_b"))
g_B <- expand.grid(x = "B", y = c("B_1", "B_2"), z = c("B_1_a", "B_1_b", "B_2_a", "B_2_b"))
g <- rbind(g_A, g_B)
n <- 123
set.seed(1)
df <- sample_n(g, n, replace = TRUE)
# Build table
tmp <- c(table(df$x)[1],
table(df$y)[1],
table(df$z)[1:2],
table(df$y)[2],
table(df$z)[3:4],
table(df$x)[2],
table(df$y)[3],
table(df$z)[5:6],
table(df$y)[4],
table(df$z)[7:8])
my_tab <- data.frame("tmp" = names(tmp), "counts" = tmp, "percentages" = round(tmp/n*100, 2))
# flextable operations
ft <- flextable(my_tab)
ft <- set_header_labels(ft, tmp = "")
ft <- align(ft, align = "center")
ft <- align(ft, j = 1, align = "left")
# ft
现在,我想缩进第一列中的一些名称。例如,要缩进 A_1
我尝试了以下策略:
compose(ft, i = 2, j = 1, as_paragraph(" A_1"))
compose(ft, i = 2, j = 1, as_paragraph("\t A_1"))
# Or
# colformat_char(ft, i = 2, j = 1, prefix = " ")
# colformat_char(ft, i = 2, j = 1, prefix = "\t")
但它们不起作用(结果与 Table 1 中的相同)。 “次佳”策略可能是以下策略 (Table 2):
compose(ft, i = 2, j = 1, as_paragraph("- A_1"))
# Or
# colformat_char(ft, i = 2, j = 1, prefix = "- ")
不过,我想要适当的缩进。
最后,我分享 Table 3 我预期的最终结果,每个“-”都用缩进代替。
等待您的见解!
再见
要缩进 flextable
中的单元格,您可以使用 padding
函数:
ft <- padding(ft, i=2, j=1, padding.left=20)
我正在构建 flextable
对象来显示表格,有时我想在第一列中添加一个或多个缩进,我在其中显示一些行的名称。
接下来我分享一些代码来模拟一些数据并有一个可重现的例子。我的问题的真正起点是 ft
(Table 1):
library(dplyr)
library(flextable)
# Simulate data
g_A <- expand.grid(x = "A", y = c("A_1", "A_2"), z = c("A_1_a", "A_1_b", "A_2_a", "A_2_b"))
g_B <- expand.grid(x = "B", y = c("B_1", "B_2"), z = c("B_1_a", "B_1_b", "B_2_a", "B_2_b"))
g <- rbind(g_A, g_B)
n <- 123
set.seed(1)
df <- sample_n(g, n, replace = TRUE)
# Build table
tmp <- c(table(df$x)[1],
table(df$y)[1],
table(df$z)[1:2],
table(df$y)[2],
table(df$z)[3:4],
table(df$x)[2],
table(df$y)[3],
table(df$z)[5:6],
table(df$y)[4],
table(df$z)[7:8])
my_tab <- data.frame("tmp" = names(tmp), "counts" = tmp, "percentages" = round(tmp/n*100, 2))
# flextable operations
ft <- flextable(my_tab)
ft <- set_header_labels(ft, tmp = "")
ft <- align(ft, align = "center")
ft <- align(ft, j = 1, align = "left")
# ft
现在,我想缩进第一列中的一些名称。例如,要缩进 A_1
我尝试了以下策略:
compose(ft, i = 2, j = 1, as_paragraph(" A_1"))
compose(ft, i = 2, j = 1, as_paragraph("\t A_1"))
# Or
# colformat_char(ft, i = 2, j = 1, prefix = " ")
# colformat_char(ft, i = 2, j = 1, prefix = "\t")
但它们不起作用(结果与 Table 1 中的相同)。 “次佳”策略可能是以下策略 (Table 2):
compose(ft, i = 2, j = 1, as_paragraph("- A_1"))
# Or
# colformat_char(ft, i = 2, j = 1, prefix = "- ")
不过,我想要适当的缩进。
最后,我分享 Table 3 我预期的最终结果,每个“-”都用缩进代替。
等待您的见解!
再见
要缩进 flextable
中的单元格,您可以使用 padding
函数:
ft <- padding(ft, i=2, j=1, padding.left=20)