R减去列表中的列

R Subtracting columns within a list

我想减去列表中的特定列。我仍在学习如何正确使用应用功能。例如,给定

> b <- list(data.frame(12:16, 3*2:6), data.frame(10:14, 2*1:5))
> b

[[1]]
  X12.16 X3...2.6
1     12        6
2     13        9
3     14       12
4     15       15
5     16       18

[[2]]
  X10.14 X2...1.5
1     10        2
2     11        4
3     12        6
4     13        8
5     14       10

我想要一些函数 x 以便我得到

> x(b)

[[1]]
  X12.16 X3...2.6  <newcol>
1     12        6         6
2     13        9         4
3     14       12         2
4     15       15         0
5     16       18        -2

[[2]]
  X10.14 X2...1.5  <newcol>
1     10        2         8
2     11        4         7
3     12        6         6
4     13        8         5
5     14       10         4

提前致谢。

如果您的 data.frames 有漂亮且一致的名称,您可以将 transformlapply

一起使用
b <- list(data.frame(a=12:16, b=3*2:6), data.frame(a=10:14, b=2*1:5))
lapply(b, transform, c=a-b)

解决方法如下:

lapply(b, function(x) {
  x[, 3] <- x[, 1] - x[, 2]
  x
})

[[1]]
  X12.16 X3...2.6 V3
1     12        6  6
2     13        9  4
3     14       12  2
4     15       15  0
5     16       18 -2

[[2]]
  X10.14 X2...1.5 V3
1     10        2  8
2     11        4  7
3     12        6  6
4     13        8  5
5     14       10  4

dplyr:

library(dplyr)
lapply(b, function(x) x %>% mutate(new_col = .[[1]]-.[[2]]))

结果:

[[1]]
  X12.16 X3...2.6 new_col
1     12        6       6
2     13        9       4
3     14       12       2
4     15       15       0
5     16       18      -2

[[2]]
  X10.14 X2...1.5 new_col
1     10        2       8
2     11        4       7
3     12        6       6
4     13        8       5
5     14       10       4