【发布时间】:2019-09-28 03:39:46
【问题描述】:
我想用 purrr 函数替换 apply()(及其派生词)。
我有一个像这样的data.frame:
> df
V1 V2 V3
1 NA 2 3
2 2 NA 3
3 3 3 NA
我想逐行应用两个函数:min(x, na.rm = T) 和 which.min(x),并将结果作为数据框返回。
如果我知道有多少列,我可以做例如这个:
pmap_dfr(df, function(V1, V2, V3) {data.frame(min = pmin(V1, V2, V3, na.rm = T),
where = which.min(c(V1, V2, V3)))})
min where
1 2 2
2 2 1
3 3 1
如何让pmap() 或任何其他purrr 函数将整行作为参数,就像apply()does 一样?
func <- function(x) {data.frame(min = min(x, na.rm = T), where = which.min(x))}
> Reduce(rbind, apply(df,1, func))
min where
V2 2 2
V1 2 1
V11 3 1
我可能只是错过了一个功能或一些技巧。感谢您的帮助。
【问题讨论】: