Ошибка: аргументы подразумевают разное количество строк: 5, 1, 2, 0 - PullRequest
0 голосов
/ 04 августа 2020

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

library(shiny)
All_Data <- data.frame(
    Name = as.character(c("2015 Acidobacteria C1", "2015 Acidobacteria C1", "2015 Acidobacteria C1", "2015 Acidobacteria C1", "2015 Actinobacteria C1")),
    Year = c(2015, 2015, 2015, 2015,2015),
    Bacteria = as.factor(c("Acidobacteria", "Acidobacteria", "Acidobacteria", "Acidobacteria","Actinobacteria")),
    Site = as.factor(c("C1", "C1", "C1", "C1","C1")),
    Percents = as.numeric(c(5,2,3,5,5)),
    stringsAsFactors = TRUE
)
ndata <-data.frame(
    Name = as.character("Preset"),
    Year = c("0"),
    Bacteria = as.factor(c("0")),
    Site = as.factor(c("0")),
    Percents = as.numeric(c("0")),
    stringsAsFactors = TRUE
)

# Define UI for application
ui <- fluidPage(

    # Application title
    titlePanel("Boxplot Maker"),

    # Sidebar
    sidebarLayout(
        sidebarPanel(
            h3("Which Data Sets Would You Like to Compare?"),
            selectInput("Set1", "", choices = All_Data$Name),
            selectInput("Set2", "",choices = All_Data$Name),
            selectInput("factor","Based on Which Factor?", choices = c("Year", "Site", "Bacteria", "Site by Year", "Bacteria by Year", "Bacteria by Site by Year")),
            textInput("title", h4("Title"), value = "Enter title..."),
            actionButton("Submit", "Submit")
        ),

        # Show a chosen plot
        mainPanel(
        uiOutput("data"),
        tableOutput("plot")
            )
    )
)

# Define server logic
server <- function(input, output) {
    output$data <- renderUI(
        conditionalPanel( condition = "input.Submit >0",
                          ndata <- filter(All_Data, All_Data$Name == input$Set1 | All_Data$Name == input$Set2)
        
    ))
    output$plot <- renderTable(
        boxplot(All_Data$Percents ~ All_Data$Year, data = All_Data, main = input$title)
    )
   }

# Run the application 
shinyApp(ui = ui, server = server)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...