r - Shiny 中的 tryCatch 错误处理

标签 r shiny

背景

我正在使用一个 Shiny 的应用程序来 cuttable一些数据。

数据集包含在 shiny 中下面的代码,但头部是:

> head(df_in)
  Report_Year Position   Target
1        2014      CEO 29.27644
2        2014      CEO 29.27644
3        2014      CFO 17.56586
4        2014       CE 17.56586
5        2014      COO 17.56586
6        2014      CEO 46.84231

我正在使用以下语句来 cuttable数据
  df <- df_in %>%
    filter(Report_Year == input$v_year,
           Position == "CEO") %>%
    select(Target) %>%
    filter(!is.na(Target)) %>%
    mutate(bins = cut(Target, breaks=seq(0, (max(Target)+25), 25))) %>%
    select(bins) %>%
    table %>%
    as.data.frame

>
         . Freq
1   (0,25]    0
2  (25,50]    6
3  (50,75]    2
4 (75,100]    1

数据中有 Report_Year == 2012 的条目,所以当用户选择 2012我希望它要么显示“无数据”之类的消息,要么现在我对空数据框感到满意。

我试过 tryCatch()声明,但我显然没有正确执行,因为当用户选择时应用程序崩溃 2012 .

问题

我应该怎么写 tryCatch ?

Shiny 应用
library(shiny)
library(dplyr)

ui <- shinyUI(fluidPage(
  sidebarLayout(
    sidebarPanel(
      selectInput("v_year", label = "select year", choices = c(2012, 2014), selected = 2014)
    ),
    mainPanel(
      dataTableOutput("dt")
    )
  )
))

server <- shinyServer(function(input, output) {


df <- reactive({

  ## data
  df_in <- structure(list(Report_Year = c(2014L, 2014L, 2014L, 2014L, 2014L, 
  2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 
  2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 
  2014L, 2014L, 2014L, 2014L, 2014L, 2014L, 2014L), Position = c("CEO", 
  "CEO", "CFO", "CE", "COO", "CEO", "CFO", "BUE", "CE", "CFO", 
  "CEO", "COO", "CE", "BUE", "COO", "CFO", "CE", "GC", "CEO", "CEO", 
  "CE", "BUE", "CEO", "CFO", "CE", "GC", "CFO", "CEO", "CEO", "CE"
  ), Target = c(29.2764408921928, 29.2764408921928, 17.5658645353157, 
  17.5658645353157, 17.5658645353157, 46.8423054275084, 38.6449019776945, 
  38.6449019776945, 38.6449019776945, 35.1317290706313, 35.1317290706313, 
  46.8423054275084, 35.1317290706313, 35.1317290706313, 43.9146613382892, 
  43.9146613382892, 35.1317290706313, 35.1317290706313, 29.2764408921928, 
  87.8293226765783, 11.7105763568771, 11.7105763568771, 29.2764408921928, 
  17.5658645353157, 35.1317290706313, 40.9870172490699, 40.9870172490699, 
  73.1911022304819, 70.2634581412627, 46.8423054275084)), class = "data.frame", .Names = c("Report_Year", 
  "Position", "Target"), row.names = c(NA, -30L))

    tryCatch({
      df <- df_in %>%
        filter(Report_Year == input$v_year,
               Position == "CEO") %>%
        select(Target) %>%
        filter(!is.na(Target)) %>%
        mutate(bins = cut(Target, breaks=seq(0, (max(Target)+25), 25))) %>%
        select(bins) %>%
        table %>%
        as.data.frame
    }, 
    warning=function(w) { 
      print("Warning")
      df <- data.frame()
      return(NA)
    }, 
    error=function(e) {
      print("Error")
      df <- data.frame()
      return(NULL)
    }
    )
})

output$dt <- renderDataTable({
  df  <- df()
})

})

shinyApp(ui = ui, server = server)

session 信息
> sessionInfo()
R version 3.2.0 (2015-04-16)
Platform: x86_64-pc-linux-gnu (64-bit)
Running under: Ubuntu 14.04.2 LTS

locale:
 [1] LC_CTYPE=en_AU.UTF-8       LC_NUMERIC=C               LC_TIME=en_AU.UTF-8        LC_COLLATE=en_AU.UTF-8    
 [5] LC_MONETARY=en_AU.UTF-8    LC_MESSAGES=en_AU.UTF-8    LC_PAPER=en_AU.UTF-8       LC_NAME=C                 
 [9] LC_ADDRESS=C               LC_TELEPHONE=C             LC_MEASUREMENT=en_AU.UTF-8 LC_IDENTIFICATION=C       

attached base packages:
[1] stats     graphics  grDevices utils     datasets  methods   base     

other attached packages:
 [1] knitr_1.10.5   rmarkdown_0.7  stringr_1.0.0  extrafont_0.17 scales_0.2.5   tidyr_0.2.0    ggplot2_1.0.1  reshape2_1.4.1
 [9] dplyr_0.4.2    shiny_0.12.1 

错误信息

appRErrorMessage

最佳答案

这样的事情怎么样?

server <- shinyServer(function(input, output) {

    df_in <- structure(...) # As before

    # Filter data according to input$v_year
    df <- reactive({
        df_in %>%
            filter(Report_Year == input$v_year, Position == "CEO") %>%
            select(Target) %>%
            filter(!is.na(Target))
    })

    # Prepare bins or return if df is empty
    bins <- reactive({
        if(nrow(df()) == 0) return()
        df() %>%
            mutate(bins = cut(Target, breaks=seq(0, (max(Target)+25), 25))) %>%
            select(bins) %>%
            table %>%
            as.data.frame
    })

    output$dt <- renderDataTable({
        bins()
    })        
})

由于我们检查是否 df()只要您的输入正确,它就是空的 seq永远不会收到空参数。

关于r - Shiny 中的 tryCatch 错误处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31366101/

相关文章:

r - 基于行和列总和的 0 和 1 条件随机矩阵

r - 提高 R Shiny 传单 map 的速度

r - 条件输出 Shiny UI

r - 如何: A scenebreak in bookdown

python - 为什么 Pandas 和 R 之间数据帧的内存使用量有如此大的差异?

r - roxygen2手动插入换行符

R,如何替换数据框中的所有空元素?

r - 在 Shiny 的多列中对齐单选按钮

r Shiny : make fileInput widget disappear after file input

r - 仅在图例中显示绘制的数据