【问题标题】:use if() to use select() within a dplyr pipe chain使用 if() 在 dplyr 管道链中使用 select()
【发布时间】:2017-11-25 11:08:27
【问题描述】:

已经阅读了这两个帖子:

我正在使用 Shiny input$selector,如果用户选择了一个特定的值,我希望我的数据框与众不同。

这是一条链:

  filtered_funnel <-  reactive({
    lastmonth_funnel %>%
      filter(input$channel == "All" | Channel == input$channel) %>%
      filter(input$promo == "All" | Promo == input$promo) %>%

      ## HERE IS WHERE I'M STRUGGLING
      {if(input$promo != "none") select(., c("Channel", "Promo", "ShippingDetails", "Checkout", "Transactions"))} %>%


      gather(Funnel, Sessions, -Channel, -Promo) %>%
      group_by(Channel, Promo, Funnel) %>%
      summarise(Sessions = sum(Sessions))
  })

如果用户输入不等于“none”,我想选择变量“Channel”、“Promo”、“ShippingDetails”、“Checkout”和“Transactions”。

我尝试了上述问题行的几种变体,但不断出现错误:

当我在管道链中尝试这个时

{if(input$promo != "none") select(., c("Channel", "Promo", "ShippingDetails", "Checkout", "Transactions"))} %>% 

我收到了这个错误:

警告:错误:所有 select() 输入必须解析为整数列 职位。以下不: * c("Channel", "Promo", "ShippingDetails", "Checkout", "Transactions")

我也试过了:

{if(input$promo != "none") select(., c(Channel, Promo, ShippingDetails, Checkout:Transactions))} %>%

这实际上会一直运行,直到我在输入中选择“无”,在这种情况下我得到 ​​p>

错误:is.character(x) 不是 TRUE

我在尝试这个时遇到了同样的错误:

{ifelse(input$promo != "none", select(., c(Channel, Promo, ShippingDetails, Checkout:Transactions)), .)} %>%

我如何在 dplyr 管道链中嵌套一条 select 语句,如果 input$promo != "none" 然后从管道中传递的对象中选择 Channel、Promo、ShippingDetails、Checkout:Transactions?

-- 这是随机生成数据的 dput--

> dput(lastmonth_funnel)
structure(list(Channel = c("Facebook", "Youtube", "SEM", "Organic", 
"Direct", "Email", "Facebook", "Youtube", "SEM", "Organic", "Direct", 
"Email", "Facebook", "Youtube", "SEM", "Organic", "Direct", "Email", 
"Facebook", "Youtube", "SEM", "Organic", "Direct", "Email", "Facebook", 
"Youtube", "SEM", "Organic", "Direct", "Email"), Promo = c("none", 
"none", "none", "none", "none", "none", "banannas", "banannas", 
"banannas", "banannas", "banannas", "banannas", "carrots", "carrots", 
"carrots", "carrots", "carrots", "carrots", "pears", "pears", 
"pears", "pears", "pears", "pears", "apples", "apples", "apples", 
"apples", "apples", "apples"), Sessions = c(6587, 3015, 6316, 
11219, 8117, 6473, 12464, 14032, 14318, 17535, 16219, 7838, 10685, 
12040, 19907, 13694, 6187, 16784, 21425, 18890, 24891, 16251, 
16977, 25206, 28573, 18704, 29178, 22069, 39687, 53734), AddToCart = c(279, 
4955, 5636, 8991, 15530, 18374, 9431, 5980, 4852, 5412, 4114, 
1782, 370, 3208, 6311, 9760, 7428, 6792, 3500, 5446, 1507, 783, 
2032, 833, 397, 2760, 5784, 9810, 13274, 14470), Registrations = c(194, 
3210, 3573, 6067, 10305, 12653, 6564, 3874, 3076, 3652, 2730, 
1227, 257, 2078, 4001, 6586, 4929, 4677, 2436, 3528, 955, 528, 
1348, 573, 276, 1788, 3667, 6620, 8808, 9964), ShippingDetails = c(134, 
2235, 2593, 4266, 7408, 9244, 4557, 2698, 2232, 2568, 1962, 896, 
178, 1447, 2904, 4631, 3543, 3417, 1691, 2457, 693, 371, 969, 
418, 191, 1245, 2661, 4655, 6332, 7280), Checkout = c(90, 1436, 
1792, 2864, 4672, 5666, 3078, 1734, 1543, 1724, 1237, 549, 120, 
930, 2007, 3109, 2234, 2094, 1142, 1579, 479, 249, 611, 256, 
129, 800, 1839, 3125, 3993, 4462), Transactions = c(59, 937, 
1192, 1819, 2602, 2926, 2039, 1132, 1026, 1095, 689, 283, 79, 
607, 1335, 1975, 1244, 1081, 756, 1031, 318, 158, 340, 132, 85, 
522, 1223, 1985, 2224, 2304)), class = "data.frame", row.names = c(NA, 
-30L), .Names = c("Channel", "Promo", "Sessions", "AddToCart", 
"Registrations", "ShippingDetails", "Checkout", "Transactions"
))

【问题讨论】:

    标签: r dplyr


    【解决方案1】:

    您需要确保无论条件如何,{ 之间的语句都会返回一个 data.frame。所以你需要一个else .

    cond <- FALSE
    
    mtcars %>% 
      group_by(cyl) %>% 
      { if (cond) filter(., am == 1) else . } %>% 
      summarise(m = mean(wt))
    

    适用于 TRUEFALSE

    (另请注意,像这样的简单示例确实使问题更容易掌握。)

    【讨论】:

    • 是的,谢谢。当我尝试使用 ifelse 时,我把 .在其他部分,想知道为什么它从来没有奏效。无论如何,这可以解决问题,谢谢
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-09-01
    • 2015-01-12
    • 1970-01-01
    • 2018-08-28
    • 2020-06-09
    • 2020-08-29
    • 2015-05-21
    相关资源
    最近更新 更多