首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >条件格式设置reactable中的多个列

条件格式设置reactable中的多个列
EN

Stack Overflow用户
提问于 2021-01-27 15:58:10
回答 1查看 734关注 0票数 0

我已经在这个问题上挣扎了一段时间了,但我的头脑还是不能理解它。

我想生成一个带有reactable的表格,但有条件地用背景阴影格式化每个(数字)列。我知道如何将其应用于列,只要手动输入每个列的名称即可。但重点是,表可以有任意(可能很大)数量的列,所以我想自动将其应用于所有列。

重要的是,列代表不同尺度上的不同变量,因此必须为每列单独应用格式。我猜秘诀是创建一个大的命名列表,即用其他列名扩展coldefs列表。

下面是一个只有一列的示例。我试图扩展它,但是遇到了很大的麻烦,所以我不打算在这里粘贴混乱的代码来迷惑任何人。任何帮助都是非常感谢的。

代码语言:javascript
复制
library(reactable)

df <- mtcars
df$mpg[2] <- NA

# Colour map for conditional formatting
orange_pal <- function(x){
  if (!is.na(x)){
    rgb(colorRamp(c("#ffe4cc", "#ffb54d"))(x), maxColorValue = 255)
  } else {
    "#e9e9e9" #grey
  }
}

# function which returns background colour based on cell value (using colour map)
stylefunc <- function(value) {
  normalized <- (value - min(mtcars$mpg)) / (max(mtcars$mpg) - min(mtcars$mpg))
  color <- orange_pal(normalized)
  list(background = color)
}

# list giving column formatting (using style function)
coldefs <- list(mpg = reactable::colDef(
  style = stylefunc
))

# create table
reactable(df,
          columns = coldefs)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-27 16:25:57

好的,就像去看医生一样,当我去寻求帮助时,我自己找到了解决方案。好了,这就是了。可能会帮助到其他人。诀窍在于colDef()style元素允许使用与该列同名的函数。使用它,我能够自动获得每列的最大值和最小值。

代码语言:javascript
复制
library(reactable)
library(magrittr)

df <- mtcars
df$mpg[2] <- NA

# Colour map for conditional formatting
orange_pal <- function(x){
  if (!is.na(x)){
    rgb(colorRamp(c("#ffe4cc", "#ffb54d"))(x), maxColorValue = 255)
  } else {
    "#e9e9e9" #grey
  }
}

# function which returns background colour based on cell value (using colour map)
# also takes column name as an input, which allows to get max and min
stylefunc <- function(value, index, name) {
  normalized <- (value - min(mtcars[name], na.rm = T)) /
    (max(mtcars[name], na.rm = T) - min(mtcars[name], na.rm = T))
  color <- orange_pal(normalized)
  list(background = color)
}

# list giving column formatting (using style function) for single column
coldefs <- list(
  reactable::colDef(style = stylefunc)
)

# get names of numerical cols
numcols <- mtcars %>% dplyr::select(where(is.numeric)) %>% colnames()
# replicate list to required length
coldefs <- rep(coldefs,length(numcols))
# name elements of list according to cols
names(coldefs) <- numcols

# create table
reactable(df,
          columns = coldefs)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65914989

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档