首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在R中使用in图的tidyeval方法

在R中使用in图的tidyeval方法
EN

Stack Overflow用户
提问于 2017-07-14 18:06:26
回答 1查看 646关注 0票数 1

Hadley刚刚创建了新的编程工具,可用于将字符串作为dplyr谓词中的函数参数传递。我想知道它是否也可以与ggplot一起使用。

创建一个自定义函数,该函数以分组变量作为输入,生成计数和给定组中行的比例百分比。这是密码。这里gprop是“群比例”函数。

代码语言:javascript
复制
library(magrittr)
library(dplyr)  

gprop <- function(df1,grouping_var,ggp=F){ # ggp = ggplot
      grouping_var_enc = enquo(grouping_var)
      df2 = df1 %>% group_by(UQ(grouping_var_enc)) %>% tally %>% mutate(`%` = round(100*n/nrow(df1))) %>%
        arrange(desc(!!grouping_var_enc)) %>% print

  if(ggp){
    p_1 = df2 %>% ggplot(aes_string(x = names(df2)[1],y='n'))  + geom_bar(stat='identity') + xlab(enquo(grouping_var))
    # p_2 = df2 %>% ggplot(aes(x = UQ(grouping_var_enc),y=n))  + geom_bar(stat='identity') + xlab(enquo(grouping_var)) # this does not work
    # p_3 = df2 %>% ggplot(aes(x = reorder(grouping_var,-n),y=n))  + geom_bar(stat='identity') + xlab(enquo(grouping_var))

    print(p1)
  }
}
set.seed(100)
df1 = tibble(a = sample(c('AA','DD','KK'),10,replace = 10),b = rnorm(10)) %>% print
gprop(df1,a,TRUE)

这是输出和图表。

代码语言:javascript
复制
#R>set.seed(100)
#R>df1 = tibble(a = sample(c('AA','DD','KK'),10,replace = 10),b = rnorm(10)) %>% print
# A tibble: 10 x 2
a                   b
<chr>               <dbl>
1    AA  0.3186300876170320
2    AA -0.5817906847159104
3    DD  0.7145327108915683
4    AA -0.8252594258627688
5    DD -0.3598621313954654
6    DD  0.0898861437775305
7    KK  0.0962744602851301
8    DD -0.2016339521833545
9    DD  0.7398404998784306
10    AA  0.1233795010888694
#R>gprop(df1,a,TRUE)
# A tibble: 3 x 3
a     n   `%`
<chr> <int> <dbl>
1    KK     1    10
2    DD     5    50
3    AA     4    40

在代码中,p_2不工作。p_1是一种黑客攻击。是否有可能使p_2工作?另外,由于p_2不能工作,所以我不能在那里添加一个重新排序(KK然后AA然后DD)变量,就像我试图通过p_3所做的那样。可能是我想错了方向。也许有一个完全不同和更好的解决办法。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-15 17:48:17

最后,通过获得这里这里的帮助,找到了答案。下面是代码和情节。我仍然很好奇,是否能以更好的方式做到这一点。

代码语言:javascript
复制
gprop <- function(df1,grouping_var,ggp=F){ # ggp = ggplot

  grouping_var_enc = enquo(grouping_var)
  df2 = df1 %>%
    group_by(UQ(grouping_var_enc)) %>% tally %>%
    mutate(`%` = round(100*n/nrow(df1))) %>%
    arrange(desc(!!grouping_var_enc)) %>% print

  if(ggp){
    p_1 = df2 %>%
      ggplot(aes_string(paste0("reorder(",quo_name(grouping_var_enc),",-n)"),y='n')) +
      geom_bar(stat='identity') + xlab(enquo(grouping_var))
    print(p_1)
  }
}

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45109238

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档