R: formattable的样式参数在输出图片上显示的内容
R: formattable's style parameters' content displayed on output picture
给定一个数据框如下:
df <- structure(list(` ` = c("v1", "v2", "v3", "v4", "v5", "v5", "v6", "v7", "v8",
"v9", "v10"), last_week = c(10, 31.34, 85.86,
3375.01, 7721.54, 9, 18.28, 58.84, 6177.73, 19890.55, 36.35),
this_week = c(27, 47.25, 99.4, 2253.04, 4861.4, 20, 43.04, 52.89,
2395.22, 2943.64, 12.67), pct = structure(c(1.7, 0.5077,
0.1577, -0.3324, -0.3704, 1.2222, 1.3545, -0.1011, -0.6123,
-0.852, -0.6515), formattable = list(formatter = "formatC",
format = list(format = "f", digits = 2L), preproc = "percent_preproc",
postproc = "percent_postproc"), class = c("formattable",
"numeric"))), class = "data.frame", row.names = c(NA, -11L
))
我尝试使用 0.2.1
版本的 formattable
包来创建一个时尚的 table:
library(formattable)
formattable(df,
list(
~formatter("span",
style = x ~ formattable::style(display = "block",
"border-radius" = "2px",
"padding" = "2px",
"text-align" = "left")
),
last_week = color_tile("#DeF7E9", "#FA614B"),
this_week = color_tile("#DeF7E9", "#FA614B"),
`pct` = formatter("span",
style = ~ style(color = ifelse(`this_week` > `last_week`, "red", "green")),
~ icontext(sapply(`pct`, function(x) if (x < 0) "arrow-down" else if (x > 0) "arrow-up" else ""), `pct`)))
)
输出:
但是如您所见,this_week
和 last_week
列不是常规数字。
以前解决过,但是更新包后好像报错了。
有人知道我该如何处理这个问题吗?谢谢。
我通过 df= :
formattable(df,
list(
df=formatter("span",
style = x ~ formattable::style(display = "block",
"border-radius" = "2px",
"padding" = "2px",
"text-align" = "left")
),
last_week = color_tile("#DeF7E9", "#FA614B"),
this_week = color_tile("#DeF7E9", "#FA614B"),
`pct` = formatter("span",
style = ~ style(color = ifelse(`this_week` > `last_week`, "red", "green")),
~ icontext(sapply(`pct`, function(x) if (x < 0) "arrow-down" else if (x > 0) "arrow-up" else ""), `pct`)))
)
给定一个数据框如下:
df <- structure(list(` ` = c("v1", "v2", "v3", "v4", "v5", "v5", "v6", "v7", "v8",
"v9", "v10"), last_week = c(10, 31.34, 85.86,
3375.01, 7721.54, 9, 18.28, 58.84, 6177.73, 19890.55, 36.35),
this_week = c(27, 47.25, 99.4, 2253.04, 4861.4, 20, 43.04, 52.89,
2395.22, 2943.64, 12.67), pct = structure(c(1.7, 0.5077,
0.1577, -0.3324, -0.3704, 1.2222, 1.3545, -0.1011, -0.6123,
-0.852, -0.6515), formattable = list(formatter = "formatC",
format = list(format = "f", digits = 2L), preproc = "percent_preproc",
postproc = "percent_postproc"), class = c("formattable",
"numeric"))), class = "data.frame", row.names = c(NA, -11L
))
我尝试使用 0.2.1
版本的 formattable
包来创建一个时尚的 table:
library(formattable)
formattable(df,
list(
~formatter("span",
style = x ~ formattable::style(display = "block",
"border-radius" = "2px",
"padding" = "2px",
"text-align" = "left")
),
last_week = color_tile("#DeF7E9", "#FA614B"),
this_week = color_tile("#DeF7E9", "#FA614B"),
`pct` = formatter("span",
style = ~ style(color = ifelse(`this_week` > `last_week`, "red", "green")),
~ icontext(sapply(`pct`, function(x) if (x < 0) "arrow-down" else if (x > 0) "arrow-up" else ""), `pct`)))
)
输出:
但是如您所见,this_week
和 last_week
列不是常规数字。
以前解决过,但是更新包后好像报错了。
有人知道我该如何处理这个问题吗?谢谢。
我通过 df= :
formattable(df,
list(
df=formatter("span",
style = x ~ formattable::style(display = "block",
"border-radius" = "2px",
"padding" = "2px",
"text-align" = "left")
),
last_week = color_tile("#DeF7E9", "#FA614B"),
this_week = color_tile("#DeF7E9", "#FA614B"),
`pct` = formatter("span",
style = ~ style(color = ifelse(`this_week` > `last_week`, "red", "green")),
~ icontext(sapply(`pct`, function(x) if (x < 0) "arrow-down" else if (x > 0) "arrow-up" else ""), `pct`)))
)