简体   繁体   English

R将数据分成组

[英]R divide data into groups

I have a data frame and I want to split one column values into n groups. 我有一个数据框,我想将一个列值拆分为n组。 So, I have a column data$dist with approximately 10k records, where max value is 23180 and min value 8951. And I want to split the values into 10 groups of equal range, ie (23180-8951)/10 = 1423. Which means that all values between 8951 and 10374 go into 1 group. 所以,我有一个大约10k记录的列data$dist ,其中最大值是23180,最小值是8951.我想将这些值分成10组相等的范围,即(23180-8951)/ 10 = 1423。表示8951和10374之间的所有值都分为1组。 And so on. 等等。 How can I do it? 我该怎么做?

You can use cut and split , as in the toy example below: 您可以使用cutsplit ,如下面的玩具示例:

set.seed(2015)
d <- data.frame(i=1:20,z=runif(20))
#     i          z
# 1   1 0.06111892
# 2   2 0.83915986
# 3   3 0.29861322
# 4   4 0.03143242
# 5   5 0.13857171
# 6   6 0.35318471
# 7   7 0.49995552
# 8   8 0.07707116
# 9   9 0.65134483
# 10 10 0.51172371
# 11 11 0.70285557
# 12 12 0.39172125
# 13 13 0.03306277
# 14 14 0.40940319
# 15 15 0.74234713
# 16 16 0.88301877
# 17 17 0.26623321
# 18 18 0.07427093
# 19 19 0.81368426
# 20 20 0.38194719

split(d,cut(d$i,seq(0,20,length.out=5)))
# $`(0,5]`
#   i          z
# 1 1 0.06111892
# 2 2 0.83915986
# 3 3 0.29861322
# 4 4 0.03143242
# 5 5 0.13857171
# 
# $`(5,10]`
#     i          z
# 6   6 0.35318471
# 7   7 0.49995552
# 8   8 0.07707116
# 9   9 0.65134483
# 10 10 0.51172371
# 
# $`(10,15]`
#     i          z
# 11 11 0.70285557
# 12 12 0.39172125
# 13 13 0.03306277
# 14 14 0.40940319
# 15 15 0.74234713
# 
# $`(15,20]`
#     i          z
# 16 16 0.88301877
# 17 17 0.26623321
# 18 18 0.07427093
# 19 19 0.81368426
# 20 20 0.38194719

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM