使用ddply分配组ID

dan*_*ota 7 r plyr

来自R新手的非常基本的表现问题.我想通过唯一的字段组合为数据框中的每一行分配一个组ID.这是我目前的做法:

> # An example data frame
> df <- data.frame(name=c("Anne", "Bob", "Chris", "Dan", "Erin"), 
                   st.num=c("101", "102", "105", "102", "150"), 
                   st.name=c("Main", "Elm", "Park", "Elm", "Main"))
> df
   name st.num st.name
1  Anne    101    Main
2   Bob    102     Elm
3 Chris    105    Park
4   Dan    102     Elm
5  Erin    150    Main
> 
> # A function to generate a random string
> getString <- function(size=10) return(paste(sample(c(0:9, LETTERS, letters), size, replace=TRUE), collapse=''))
>
> # Assign a random string for each unique street number + street name combination
> df <- ddply(df, 
              c("st.num", "st.name"), 
              function(x) transform(x, household=getString()))
> df
   name st.num st.name  household
1  Anne    101    Main 1EZWm4BQel
2   Bob    102     Elm xNaeuo50NS
3   Dan    102     Elm xNaeuo50NS
4 Chris    105    Park Ju1NZfWlva
5  Erin    150    Main G2gKAMZ1cU
Run Code Online (Sandbox Code Playgroud)

虽然这适用于行数相对较少或组数较少的数据帧,但我遇到了具有许多唯一组的较大数据集(> 100,000行)的性能问题.

有什么建议可以提高这项任务的速度吗?可能与plyr的实验性idata.frame()?或者我这样做是错的?

在此先感谢您的帮助.

had*_*ley 14

尝试使用该id功能(也在plyr中):

df$id <- id(df[c("st.num", "st.name")], drop = TRUE)
Run Code Online (Sandbox Code Playgroud)

更新:

id自dplyr版本0.5.0起,该函数被认为已弃用.该功能group_indices提供相同的功能.