Надеюсь, у вас все хорошо.Я сталкиваюсь с проблемой в реактивной части сервера (если еще операторы).При выборе TTS и NTTS с использованием radioButtons мне требуются столбцы из 1: 6 и 7:11 данных mtcars соответственно.Я приложил фотографии, которые соответствуют желаемому результату.Я также приложил свои коды, может кто-нибудь, пожалуйста, выяснить, что с ними не так?Большое спасибо :)
library(shiny)
library(tidyr)
library(dplyr)
library(readr)
library(DT)
data_table <- mtcars
# Define UI
ui <- fluidPage(
downloadButton('downLoadFilter',"Download the filtered data"),
radioButtons(inputId = "columns", label = "choose variable",
choices =c("All","TTS", "NTTS"),
selected = c("All")),
selectInput(inputId = "cyl",
label = "cyl:",
choices = c("All",
unique(as.character(data_table$cyl))),
selected = "4",
multiple = TRUE),
selectInput(inputId = "vs",
label = "vs:",
choices = c("All",
unique(as.character(data_table$vs))),
selected = "1",
multiple = TRUE),
DT::dataTableOutput('ex1'))
server <- function(input, output) {
thedata <- reactive({
if(input$columns=='All'){
data_table
}
else if (input$columns== 'TTS'){
data_table<- data_table[,c(1:6),drop=FALSE] }
else
data_table<- data_table[,c(7:11),drop=FALSE]
if(input$cyl != 'All'){
data_table<-data_table[data_table$cyl %in% input$cyl,]
}
if(input$vs != 'All'){
data_table<-data_table[data_table$vs %in% input$vs,]
}
else
data_table })
output$ex1 <- DT::renderDataTable(DT::datatable(filter = 'top',
escape = FALSE,
options = list(pageLength =
10,
scrollX='500px',autoWidth = TRUE),{
thedata() # Call reactive
}))
output$downLoadFilter <- downloadHandler(
filename = function() {
paste('Filtered data-', Sys.Date(), '.csv', sep = '')
},
content = function(path){
write_csv(thedata(),path) # Call reactive thedata()
})}
shinyApp(ui = ui, server = server)