如何在闪亮的反应式表达式中使用data.table?

Ale*_*lex 5 r shiny data.table

使用以下代码data.dable可以选择 a 的列。

mtcars_dt <- data.table(mtcars)
selected_cols <- c("mpg")
mtcars_dt[ ,..selected_cols]
Run Code Online (Sandbox Code Playgroud)

我想在闪亮的反应式表达式中做同样的事情。然而,它的行为很奇怪。这是一个可重现的示例

library(shiny)
library(data.table)
mtcars_dt <- data.table(mtcars)

ui <- basicPage(
  selectInput("var", "Select variable", names(mtcars)),
  textOutput("out1"),
  textOutput("out2")
)


server <- function(input, output) {

output$out1 <- renderText({
    mtcars[1:3 ,input$var]
  })

output$out2 <- renderText({
  mtcars_dt[1:3 , ..input$var]
})

}

shinyApp(ui, server)
Run Code Online (Sandbox Code Playgroud)

当我运行此应用程序时,第二个输出是一个字符串,其中包含我要选择的列的名称。

为什么会发生这种情况?我该如何解决它?

ism*_*gal 2

请检查以下选项:

library(shiny)
library(data.table)

mtcars_dt <- data.table(mtcars)

ui <- basicPage(
  selectInput("var", "Select variable", names(mtcars)),
  textOutput("out1"),
  textOutput("out2")
)


server <- function(input, output) {

  output$out1 <- renderText({
    mtcars[1:3, input$var]
  })

  output$out2 <- renderText({
    cols <- input$var
    unlist(mtcars_dt[1:3, ..cols])

    # 1. alternative
    # mtcars_dt[1:3][[input$var]]

    # 2. alternative
    # mtcars_dt[1:3, get(input$var)]

    # 3. alternative
    # unlist(mtcars_dt[1:3, .SD, .SDcols = input$var])

    # 4. alternative
    # unlist(mtcars_dt[1:3, input$var, with = FALSE])
  })

}

shinyApp(ui, server)
Run Code Online (Sandbox Code Playgroud)

  • 截至目前,“..”前缀适用于符号(如“cols”)。`input$var` 实际上是 `$(input, var)` 调用,而不是符号。 (4认同)