基于上载数据的动态输入选择器

时间:2015-01-23 22:44:33

标签: r shiny shiny-server

提前感谢您的帮助。我理解如何根据预定义数据集的其他输入操作动态输入。 即加载汽车数据集。用户选择单选按钮说他们只想看蓝色车。这会更改UI上某些输入选择器中的选项。

但是,如果我想允许用户上传csv文件,我该如何动态更新所有相关的小部件。 即,用户上传其数据,输入选择器显示数据集中的所有变量,用于绘图和回归。

斜体部分是我的麻烦。

ui.r

library(shiny)

# Define UI for application that draws a histogram
shinyUI(fluidPage(

  titlePanel("My R Shiny App"),

  sidebarPanel(
    fileInput('file', 'Choose file to upload.'),
    #Select Box: y
    selectInput("y_input", label = h5("Select Time Series/Response Variable"),
                choices = names(myData),
                selected = NULL)

  )
) 
)

server.r

library(shiny)

#Run once when app is launched
#Load data

shinyServer(function(input, output) {

  #Run once each time a user visits the app
  #Put code to build a distinct set of reactive objects for user


  output$Variable_Selector <- renderUI({
    if(is.null(input$file))
      return(NULL)
    inFile <- input$file
    myData <- read.csv(inFile$datapath)
    if (is.null(myData))
      return(NULL)
  })
})

global.r

myData = NULL

谢谢!

1 个答案:

答案 0 :(得分:7)

以下是使用函数observeupdateSelectInput的一个解决方案 - 以及对代码的一些其他细微修改。为了演示我使用不同列名创建了以下两个csv文件:

Df1 <- data.frame(
  x=1:5,
  y=2*(1:5),
  z=3*(1:5))
##
Df2 <- data.frame(
  a=6:10,
  b=2*(6:10),
  c=3*(6:10),
  d=letters[1:5],
  stringsAsFactors=F)
##
write.csv(Df1,file="~/tempfiles/Df1.csv",row.names=F)
##
write.csv(Df2,file="~/tempfiles/Df2.csv",row.names=F)

ui.R

library(shiny)

shinyUI(fluidPage(

  titlePanel("My R Shiny App"),

  sidebarPanel(

    fileInput(
      'file', 
      'Choose file to upload.'
    ),

    selectInput(
      "y_input", 
      label = h5("Select Time Series/Response Variable"),
      ""
    )

  )

))

server.R

library(shiny)

shinyServer(function(input, output, session) {

  inFile <- reactive({
    if (is.null(input$file)) {
      return(NULL)
    } else {
      input$file
    }
  })

  myData <- reactive({
    if (is.null(inFile())) {
      return(NULL)
    } else {
      read.csv(inFile()$datapath)
    }
  })

  observe({
    updateSelectInput(
      session,
      "y_input",
      choices=names(myData()))

  })

})

global.R

myData <- NULL

以下是一些截图,展示了UI如何根据上传的文件进行更改:

Uploading <code>Df1.csv</code>

Uploading <code>Df2.csv</code>