首页 > 解决方案 > 如何在R中的所有行中获取每列的百分比值

问题描述

使用 R 的 tidyverse,我如何获得每列跨行的百分比值?以 mpg 数据集为例,我尝试了以下代码:

new_mpg <- mpg %>%
  group_by(manufacturer, model) %>%
    summarise (n = n()) %>% 
      spread(model, n) %>% 
        mutate_if(is.integer, as.numeric)

new_mpg[,-1] %>% 
  mutate(sum = rowSums(.))

我正在寻找创建以下输出:

manufacturer | 4runner4wd |     a4    | a4 quattro | a6 quattro | altima |
--------------------------------------------------------------------------
audi         |     NA     | 0.3888889 |   0.444444 | 0.166667   |   NA   |

但是,当我到达

new_mpg[,-1] %>% 
      mutate(sum = rowSums(.))

sum 列返回 NA。而且我无法计算 n()/sum。我只会得到NA。任何想法如何解决这一问题?

标签: rdplyrpercentage

解决方案


正如@camille 在评论中提到的那样,您需要na.rm = TRUErowSums通话中使用。要获得制造商中每个型号的百分比,您需要首先计算按制造商和型号分组的每个型号的数量,然后获得仅按制造商分组的百分比。dplyr这种方式很聪明,因为它在之后删除了一层分组,summarise所以你只需要添加一个 mutate:

library(dplyr)
library(tidyr)
library(ggplot2)
new_mpg <- mpg %>%
  group_by(manufacturer, model) %>%
  summarise (n = n()) %>% 
  mutate(n = n/sum(n)) %>% 
  spread(model, n) %>% 
  mutate_if(is.integer, as.numeric)

new_mpg[,-1] %>% 
  mutate(sum = rowSums(., na.rm = TRUE))

推荐阅读