R data.table 将函数应用于两列的总和



我有一个data.table,我想在其列上应用一个函数。通常这样做是这样的:

dt[, lapply(.SD, func), .SDcols = c("col1", "col2")]

这将在这两列上应用函数func。但是,如果我想将其应用于这两列的总和怎么办?类似的东西

dt[, lapply(.SD, func), .SDcols = "col1 + col2"]

显然行不通。

您可以将其推广为将func应用于另一个函数(在本例中为 sum)的结果,该函数将列作为参数。我知道我可以创建另一个包含第一个函数结果的列,但是有没有办法解决这个问题?

要添加列,请尝试

dt[, func(Reduce(`+`,.SD)), .SDcols = c("col1","col2")]

这也适用于两列以上的列,在应用 func 之前将它们全部加在一起。

最新更新