29

いくつかの列を持つデータフレームがあり、それらの列の1つはランクで、1〜20の整数です。「1-4」、「5-10」、「11-」などのビン値を含む別の列を作成したいと思います。 15 "、"16-20"。

これを行うための最も効果的な方法は何ですか?

私が持っているデータフレームは次のようになります(.csv形式):

rank,name,info
1,steve,red
3,joe,blue
6,john,green
3,liz,yellow
15,jon,pink

データフレームに別の列を追加したいので、次のようになります。

rank,name,info,binValue
1,steve,red,"1-4"
3,joe,blue,"1-4"
6,john,green, "5-10"
3,liz,yellow,"1-4"
15,jon,pink,"11-15"

data.frameをそのまま維持し、df $rankedの値が指定された範囲内にある場合は別の列を追加したいので、現在の方法は機能していません。ありがとうございました。

4

3 に答える 3

56

参照?cutして指定してくださいbreaks(そしておそらくlabels)。

x$bins <- cut(x$rank, breaks=c(0,4,10,15), labels=c("1-4","5-10","10-15"))
x
#   rank  name   info  bins
# 1    1 steve    red   1-4
# 2    3   joe   blue   1-4
# 3    6  john  green  5-10
# 4    3   liz yellow   1-4
# 5   15   jon   pink 10-15
于 2011-04-06T17:17:01.653 に答える
7
dat <- "rank,name,info
1,steve,red
3,joe,blue
6,john,green
3,liz,yellow
15,jon,pink"

x <- read.table(textConnection(dat), header=TRUE, sep=",", stringsAsFactors=FALSE)
x$bins <- cut(x$rank, breaks=seq(0, 20, 5), labels=c("1-5", "6-10", "11-15", "16-20"))
x

  rank  name   info  bins
1    1 steve    red   1-5
2    3   joe   blue   1-5
3    6  john  green  6-10
4    3   liz yellow   1-5
5   15   jon   pink 11-15
于 2011-04-06T17:19:13.463 に答える