gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-04 11:20:44 26 4
gpt4 key购买 nike

我有一个 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 之前将它们全部加在一起。

关于R data.table 将函数应用于两列的总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29934354/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com