【发布时间】:2017-01-16 01:54:05
【问题描述】:
我发现这个线程Find rows in dataframe with maximum values grouped by values in another column 已经讨论了其中一个解决方案。我正在使用此解决方案以递归方式查找最大数量的行索引。但是,我的解决方案非常难看——非常程序化而不是矢量化。
这是我的虚拟数据:
dput(Data)
structure(list(Order_Year = c(1999, 1999, 1999, 1999, 1999, 1999,
1999, 2000, 2000, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2002,
2002, 2002, 2002), Ship_Year = c(1997, 1998, 1999, 2000, 2001,
2002, NA, 1997, NA, 1997, 1998, 1999, 2000, 2001, 2002, NA, 1997,
1998, 1999, 2000), Yen = c(202598.2, 0, 0, 0, 0, 0, 2365901.62,
627206.75998, 531087.43, 122167.02, 143855.55, 0, 0, 0, 0, 53650.389998,
17708416.3198, 98196.4, 31389, 0), Units = c(37, 1, 8, 5, 8,
8, 730, 99, 91, 195, 259, 4, 1, 3, 3, 53, 3844, 142, 63, 27)), .Names = c("Order_Year",
"Ship_Year", "Yen", "Units"), row.names = c(NA, 20L), class = "data.frame")
我想找出给定Order_Year 的Yen 和Units 最大的Ship_Year。
这是我尝试过的:
a<-do.call("rbind", by(Data, Data$Order_Year, function(x) x[which.max(x$Yen), ]))
rownames(a)<-NULL
a$Yen<-NULL
a$Units<-NULL
#a has Ship_Year for which Yen is max for a given Order_Year
names(a)[2]<-"by.Yen"
#Now I'd find max year by units
b<-do.call("rbind", by(Data, Data$Order_Year, function(x) x[which.max(x$Units), ]))
rownames(b)<-NULL
b$Yen<-NULL
b$Units<-NULL
#b has Ship_Year for which Units is max for a given Order_Year
names(b)[2]<-"by.Qty"
c<-a %>% left_join(b)
预期的输出是:
c
Order_Year by.Yen by.Qty
1 1999 NA NA
2 2000 1997 1997
3 2001 1998 1998
4 2002 1997 1997
虽然我得到了预期的输出,但上面的方法非常笨拙。有没有更好的方法来处理这个问题?
【问题讨论】:
标签: r