DT::Datatable 的正值和负值用不同的颜色表示

fir*_*o23 4 javascript r dt

DT::Datatable我正在尝试根据此代码块分别用绿色和红色对a 的某一列(第三列)的正值和负值进行着色,但我不是 javascript 用户。有什么办法可以设置这个吗?

library(DT)

datatable(head(iris)) %>% 
    formatStyle(1:4, color = JS("value % 1 === 0 ? 'red' : ''"))
Run Code Online (Sandbox Code Playgroud)

Jor*_*hau 7

您可以DT::styleInterval为此使用:

library(DT)

## data (iris dataset contains no negative values)
dat <- data.frame(
    letters = LETTERS[1:26],
    numbers = sample(c(-1, -0.5, 0, 0.5, 1), 26, replace = TRUE)
)

datatable(dat) %>%
    formatStyle(
        columns = "numbers", 
        color = styleInterval(cuts = 0, values = c("red", "green")),
        fontWeight = "bold"
    )
Run Code Online (Sandbox Code Playgroud)

dt_img


注意:如果应忽略零值,您可以将黑色设置为零周围的小区域:

eps <- 1E-5

datatable(dat) %>%
    formatStyle(
        columns = "numbers", 
        color = styleInterval(cuts = c(-eps, eps), values = c("red", "black", "green")),
        fontWeight = "bold"
    )
Run Code Online (Sandbox Code Playgroud)