我的意思是这样的:
我有一个DataFrame
可能是分类或名义的列。对于每个观察(行),我想生成一个新行,其中变量的每个可能值现在都是它自己的二进制变量。例如,这个矩阵(第一行是列标签)
'a' 'b' 'c'
one 0.2 0
two 0.4 1
two 0.9 0
three 0.1 2
one 0.0 4
two 0.2 5
将被转换成这样的东西:
'a' 'b' 'c'
one two three [0.0,0.2) [0.2,0.4) [0.4,0.6) [0.6,0.8) [0.8,1.0] 0 1 2 3 4 5
1 0 0 0 1 0 0 0 1 0 0 0 0 0
0 1 0 0 0 0 0 1 0 1 0 0 0 0
0 1 0 0 0 0 0 1 1 0 0 0 0 0
0 0 1 1 0 0 0 0 0 0 1 0 0 0
1 0 0 1 0 0 0 0 0 0 0 0 1 0
0 1 0 0 1 0 0 0 0 0 0 0 0 1
初始矩阵中的每个变量(列)都被合并到所有可能的值中。如果它是分类的,那么每个可能的值都会成为一个新列。如果它是一个浮点数,那么这些值会以某种方式分箱(例如,总是分成 10 个箱)。如果它是一个 int,那么它可以是每个可能的 int 值,或者也可能是 binning。
仅供参考:在我的实际应用程序中,表格最多有 200 万行,而完整的“扩展”矩阵可能有数百列。
有没有简单的方法来执行这个操作?
另外,我也愿意跳过这一步,因为我真的想计算一个 Burt 表(这是交叉表的对称矩阵)。有没有一种简单的方法可以用这个函数做类似的事情crosstab
?否则,计算交叉表只是一个简单的矩阵乘法。