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)
当我运行此应用程序时,第二个输出是一个字符串,其中包含我要选择的列的名称。
为什么会发生这种情况?我该如何解决它?
请检查以下选项:
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)
归档时间: |
|
查看次数: |
366 次 |
最近记录: |