Проблема с выбором столбцов в выбранных столбцах с помощью RadioButtons в ShinyApp - PullRequest
0 голосов
/ 29 ноября 2018

Я создаю inyApp, используя R .Я использую radioButtons , чтобы выбрать столбцы, а затем снова использую radiobuttons , чтобы выбрать другие столбцы в предыдущих выбранных столбцах.Я не могу этого сделать, так как получаю сообщение об ошибке всякий раз, когда выбираю что-либо, кроме Все из выберите переменную ',' выберите волны 'и' выберите волну '.

Я считаю, что проблема заключается в реактивной части сервера .Может кто-нибудь, пожалуйста, посмотрите на мои коды?Буду крайне признателен :)

library(shiny)
library(tidyr)
library(dplyr)
library(readr)
library(DT)

data_table<-mtcars[,c(2,8,1,3,4,5,9,6,7, 10,11)]

data_table$disp<-NULL

names(data_table)[3:10]<- rep(x = 
c('TS_lhr_Wave_1','TS_isb_Wave_2','TS_quta_Wave_1','TS_karach_Wave_2', 

'NTS_lhr_Wave_1','NTS_isb_Wave_2','NTS_quta_Wave_1','NTS_karach_Wave_2'), 
times=1, each=1)



# Define UI
ui <- fluidPage(
downloadButton('downLoadFilter',"Download the filtered data"),

radioButtons(inputId = "columns", label = "choose variable",
           choices =c("All","TS", "NTS"), inline =TRUE,
           selected = c("TS")),

radioButtons(inputId = "regions", label = "choose region",
           choices =c("All", "lhr", "isb", "quta", "karach"), inline = TRUE,
           selected = c("lhr")),

radioButtons(inputId = "waves", label = "choose wave",
           choices =c("All", "Wave_1", "Wave_2"), inline = TRUE,
           selected = c("Wave_1")),


selectInput(inputId = "cyl",
          label = "cyl:",
          choices = c("All",
                      unique(as.character(data_table$cyl))),
          selected = "All",
          multiple = TRUE),


selectInput(inputId = "vs",
          label = "vs:",
          choices = c("All",
                      unique(as.character(data_table$vs))),
          selected = "All",
          multiple = TRUE),

DT::dataTableOutput('ex1'))


# Define Server
server <- function(input, output) {

thedata <- reactive({

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,]
}


#TS NTS
if  (input$columns== 'TS'){
  data_table<-  data_table[,c(1,2, 3,4,5,6),drop=FALSE]    }


if  (input$columns== 'NTS'){
  data_table<-  data_table[,c(1,2,7,8,9,10),drop=FALSE]    }



#region
if  (input$regions== 'lhr' ){
  data_table<-  data_table[,c(1,2,3,7),
                           drop=FALSE]    }

if  (input$regions== 'isb' ){
  data_table<-  data_table[,c(1,2,4,8),
                           drop=FALSE]    }


if  (input$regions== 'quta' ){
  data_table<-  data_table[,c(1,2,5,9),
                           drop=FALSE]    }


if  (input$regions== 'karach' ){
  data_table<-  data_table[,c(1,2,6,10),
                           drop=FALSE]    }


#waves
if  (input$waves== 'Wave_1' ){
  data_table<-  data_table[,c(1,2,3,5,7, 9),
                           drop=FALSE]    }

if  (input$waves== 'Wave_2' ){
  data_table<-  data_table[,c(1,2,4,6, 8, 10),
                           drop=FALSE]    }


else
  data_table })

output$ex1 <- DT::renderDataTable(DT::datatable(filter = 'top',
                                              escape = FALSE, 
                                              options = list(pageLength = 
                                                               10, 

scrollX='500px',autoWidth = TRUE),{
                                                               thedata()  
}))

output$downLoadFilter <- downloadHandler(
filename = function() {
  paste('Filtered data-', Sys.Date(), '.csv', sep = '')
},
content = function(path){
  write_csv(thedata(),path)   })}

shinyApp(ui = ui, server = server)

1 Ответ

0 голосов
/ 29 ноября 2018

Я не знаю точно, как вы хотите построить эту логику, но вот пример того, как отключить и включить некоторые входы.Он по-прежнему выдает ошибку в консоли, но, по крайней мере, все отображается правильно в приложении.

library(shiny)
library(tidyr)
library(dplyr)
library(readr)
library(DT)
library(shinyjs)

data_table<-mtcars[,c(2,8,1,3,4,5,9,6,7, 10,11)]

data_table$disp<-NULL

names(data_table)[3:10]<- rep(x = 
                                c('TS_lhr_Wave_1','TS_isb_Wave_2','TS_quta_Wave_1','TS_karach_Wave_2',                                  
                                  'NTS_lhr_Wave_1','NTS_isb_Wave_2','NTS_quta_Wave_1','NTS_karach_Wave_2'), 
                              times=1, each=1)


# Define UI
ui <- {fluidPage(
  useShinyjs(),
  downloadButton('downLoadFilter',"Download the filtered data"),

  radioButtons(inputId = "columns", label = "choose variable",
               choices =c("All","TS", "NTS"), inline =TRUE,
               selected = c("All")),

  radioButtons(inputId = "regions", label = "choose region",
               choices =c("All", "lhr", "isb", "quta", "karach"), inline = TRUE,
               selected = c("All")),

  radioButtons(inputId = "waves", label = "choose wave",
               choices =c("All", "Wave_1", "Wave_2"), inline = TRUE,
               selected = c("All")),


  selectInput(inputId = "cyl",
              label = "cyl:",
              choices = c("All",
                          unique(as.character(data_table$cyl))),
              selected = "All",
              multiple = TRUE),


  selectInput(inputId = "vs",
              label = "vs:",
              choices = c("All",
                          unique(as.character(data_table$vs))),
              selected = "All",
              multiple = TRUE),

  DT::dataTableOutput('ex1', width="100%")
)}


# Define Server
server <- function(input, output, session) {

  observe({
    if (input$columns != "All") {
      updateRadioButtons(session, "regions", selected = "All")
      updateRadioButtons(session, "waves", selected = "All")

      shinyjs::disable("regions")
      shinyjs::disable("waves")
    } else {
      shinyjs::enable("regions")
      shinyjs::enable("waves")
    }

    if (input$regions != "All") {
      shinyjs::disable("waves")
    }
    if (input$waves != "All") {
      shinyjs::disable("regions")
    }
  })



  thedata <- reactive({

    #TS NTS
    if  (input$columns == 'TS'){
      data_table<-  data_table[,c("cyl","vs", "TS_lhr_Wave_1", "TS_isb_Wave_2", "TS_quta_Wave_1", "TS_karach_Wave_2"),drop=FALSE]    }
    if  (input$columns == 'NTS'){
      data_table<-  data_table[,c("cyl","vs","NTS_lhr_Wave_1", "NTS_isb_Wave_2","NTS_quta_Wave_1", "NTS_karach_Wave_2"),drop=FALSE]    }

    #waves
    if  (input$waves == 'Wave_1' ){
      data_table<-  data_table[,c("cyl","vs","TS_lhr_Wave_1","TS_quta_Wave_1","NTS_lhr_Wave_1", "NTS_quta_Wave_1"), drop=FALSE]    }
    if  (input$waves == 'Wave_2' ){
      data_table<-  data_table[,c("cyl","vs","TS_isb_Wave_2","TS_karach_Wave_2", "NTS_isb_Wave_2", "NTS_karach_Wave_2"), drop=FALSE]    }

    #region
    if  (input$regions == 'lhr' ){
      data_table<-  data_table[,c("cyl","vs","TS_lhr_Wave_1","NTS_lhr_Wave_1"), drop=FALSE]    }
    if  (input$regions == 'isb' ){
      data_table<-  data_table[,c("cyl","vs","TS_isb_Wave_2","NTS_isb_Wave_2"), drop=FALSE]    }
    if  (input$regions == 'quta' ){
      data_table<-  data_table[,c("cyl","vs","TS_quta_Wave_1","NTS_quta_Wave_1"), drop=FALSE]    }
    if  (input$regions == 'karach' ){
      data_table<-  data_table[,c("cyl","vs","TS_karach_Wave_2","NTS_karach_Wave_2"), drop=FALSE]    }

    ## cyl / vs
    if (any(input$cyl != 'All')){
      data_table<-data_table[data_table$cyl %in%   input$cyl,] 
    }
    if(any(input$vs != 'All')){
      data_table<-data_table[data_table$vs %in%  input$vs,]
    }

    req(data_table)

    data_table
  })

  output$ex1 <- DT::renderDataTable({
    req(thedata())

    DT::datatable(filter = 'top', escape = FALSE, width = "100%",
                  options = list(pageLength =  10, 
                                 scrollX='500px',autoWidth = TRUE),{
                                   thedata()  
                                 })
  })

  output$downLoadFilter <- downloadHandler(
    filename = function() {
      paste('Filtered data-', Sys.Date(), '.csv', sep = '')
    },
    content = function(path){
      write_csv(thedata(),path)   })
}

shinyApp(ui = ui, server = server)
...