group_by的价值在于对 从对整个数据框的数据处理,转换为对每个组内的数据处理。
如:> not_cancelled %>%group_by(year,month,day)%>%filter(rank(desc(arr_delay))<=10) %>% select(month,year,day,arr_delay) #取各组内的前10记录。
> not_cancelled %>%filter(rank(desc(arr_delay))<=10) %>% select(month,year,day,arr_delay) #取数据框所有数据的前10记录。
- 摘要函数 如mean() ,median() 适用以分组为基础计算 如 gf %>%mutate(mean(x))
- 对已有变量单个值的运算符不适用按向量分组分组。如 + - log() %/% %% < == 等。 如 gf %>%mutate(z=x+2)
- 偏移函数lag(),lead(),min_rank(),row_number() 同样会按组计算 如
- gf %>%mutate(lag_x=lag(x),lead_x=lead(x))
- gf %>% mutate(min_rank(x))
-
-
其中取每个分组的第一个值gf %>% filter(min_rank(x)==1)
-
arrange()需要指定.group=TRUE,才适用。如df %>% group_by(group) %>%arrange(x,.by_group=TRUE)
lag() 返回向量中元素前一个值
lead() 返回向量中元素后一个值
#Find the "previous" (lag()
) or "next" (lead()
) values in a vector. Useful for comparing values behind of or ahead of the current values.