如何在 R 数据框中创建一个包含两列乘积的新列?
有时我们需要将两列相乘并创建一个新列,以便将乘积进一步用于分析。例如,要计算 BMI,我们需要质量和身高,并且身高需要平方,因此我们需要计算身高的平方。为此,我们可以将身高乘以身高,或者直接取平方,两种方法都可以。因此,如果 R 数据框中只有身高列,则可以将其自身相乘。
示例
考虑以下数据框:
> set.seed(957) > x<-rpois(20,1) > y<-rpois(20,5) > z<-rpois(20,3) > df<-data.frame(x,y,z) > df
输出
x y z 1 0 1 3 2 0 7 3 3 0 6 7 4 3 7 3 5 1 3 7 6 0 3 4 7 1 3 5 8 0 4 2 9 0 5 0 10 0 4 3 11 0 3 7 12 0 8 3 13 1 7 5 14 1 5 5 15 1 10 7 16 0 5 3 17 0 7 2 18 0 5 4 19 0 4 4 20 0 5 2
创建包含不同列乘积的新列:
示例
> df$xy<-df$x*df$y > df
输出
x y z xy 1 0 1 3 0 2 0 7 3 0 3 0 6 7 0 4 3 7 3 21 5 1 3 7 3 6 0 3 4 0 7 1 3 5 3 8 0 4 2 0 9 0 5 0 0 10 0 4 3 0 11 0 3 7 0 12 0 8 3 0 13 1 7 5 7 14 1 5 5 5 15 1 10 7 10 16 0 5 3 0 17 0 7 2 0 18 0 5 4 0 19 0 4 4 0 20 0 5 2 0
示例
> df$xz<-df$x*df$z > df
输出
x y z xy xz 1 0 1 3 0 0 2 0 7 3 0 0 3 0 6 7 0 0 4 3 7 3 21 9 5 1 3 7 3 7 6 0 3 4 0 0 7 1 3 5 3 5 8 0 4 2 0 0 9 0 5 0 0 0 10 0 4 3 0 0 11 0 3 7 0 0 12 0 8 3 0 0 13 1 7 5 7 5 14 1 5 5 5 5 15 1 10 7 10 7 16 0 5 3 0 0 17 0 7 2 0 0 18 0 5 4 0 0 19 0 4 4 0 0 20 0 5 2 0 0
示例
> df$yz<-df$y*df$z > df
输出
x y z xy xz yz 1 0 1 3 0 0 3 2 0 7 3 0 0 21 3 0 6 7 0 0 42 4 3 7 3 21 9 21 5 1 3 7 3 7 21 6 0 3 4 0 0 12 7 1 3 5 3 5 15 8 0 4 2 0 0 8 9 0 5 0 0 0 0 10 0 4 3 0 0 12 11 0 3 7 0 0 21 12 0 8 3 0 0 24 13 1 7 5 7 5 35 14 1 5 5 5 5 25 15 1 10 7 10 7 70 16 0 5 3 0 0 15 17 0 7 2 0 0 14 18 0 5 4 0 0 20 19 0 4 4 0 0 16 20 0 5 2 0 0 10
广告