Use dplyr::percent_rank() to compute percentile ra

2020-05-27 04:00发布

Suppose I have the following data:

id    grpvar1    grpvar2    value
1     1          3          7.6
2     1          2          4
...
3     1          5          2

For each id, I want to compute the percent_rank() of its value within the group defined by the combination of grpvar1 and grpvar2.

Using data.table, I would go (assuming I my data is in a data.frame called dataf:

library(data.table)

# Make dataset into a data.table.
dt <- data.table(dataf)

# Calculate the percentiles.
dt[, percrank := rank(value)/length(value), by = c("grpvar1", "grpvar2")]

What is the equivalent in dplyr?

标签: r dplyr
1条回答
来,给爷笑一个
2楼-- · 2020-05-27 04:42

Try:

 library(dplyr)
 dataf %>%
 group_by(grpvar1, grpvar2) %>% 
 mutate(percrank=rank(value)/length(value))
查看更多
登录 后发表回答