如何将 data.table 对象中的相应行值与 R 中的单行 data.table 对象相乘?
要将data.table具有多行的对象中的行值与data.tableR中的单行对象相乘,我们可以按照以下步骤操作-
首先,创建一个data.table多行data.table对象和一个单行对象。
然后,使用mapply函数将这些对象中的行值相乘。
示例
创建第一个data.table对象
让我们创建一个data.table对象,如下所示-
library(data.table) x1<-sample(1:10,25,replace=TRUE) x2<-sample(1:10,25,replace=TRUE) DT1<-data.table(x1,x2) DT1输出结果
执行时,上述脚本生成以下内容output(thisoutputwillvaryonyoursystemduetorandomization)-
x1 x2
1: 8 1
2: 4 2
3: 8 5
4: 4 1
5: 10 2
6: 5 10
7: 9 3
8: 6 5
9: 1 6
10: 7 1
11: 9 7
12: 8 9
13: 4 10
14: 10 6
15: 1 4
16: 8 1
17: 10 4
18: 7 1
19: 3 1
20: 3 7
21: 2 8
22: 4 9
23: 5 8
24: 4 7
25: 3 1
x1 x2创建第二个data.table对象
让我们创建一个data.table对象,如下所示-
DT2<-data.table(y1=5,y2=0) DT2输出结果
y1 y2 1: 5 0
将两个data.table对象的值相乘
使用mapply函数将data.table具有多行的对象DT1中的行值与单行data.table对象DT2相乘-
library(data.table) x1<-sample(1:10,25,replace=TRUE) x2<-sample(1:10,25,replace=TRUE) DT1<-data.table(x1,x2) DT2<-data.table(y1=5,y2=0) mapply(`*`,DT1,DT2)输出结果
x1 x2 [1,] 40 0 [2,] 20 0 [3,] 40 0 [4,] 20 0 [5,] 50 0 [6,] 25 0 [7,] 45 0 [8,] 30 0 [9,] 5 0 [10,] 35 0 [11,] 45 0 [12,] 40 0 [13,] 20 0 [14,] 50 0 [15,] 5 0 [16,] 40 0 [17,] 50 0 [18,] 35 0 [19,] 15 0 [20,] 15 0 [21,] 10 0 [22,] 20 0 [23,] 25 0 [24,] 20 0 [25,] 15 0