熊猫系列元素组合

时间:2017-11-10 06:50:05

标签: python pandas multiplication elementwise-operations

我有两个大熊猫系列a和b如下:

a = pd.series([1, 2, 3])

b = pd.series([[1, 2, 3], [4, 5, 6], [7, 8, 9]])

我想得到的是第三个大熊猫系列如下:

[[1, 2, 3], [8, 10, 12], [21, 24, 27]]

我尝试过以下操作:

a*b

np.array(a)*np.array(b)

np.multiple(a, b)

a.multiple(b)

但是,我一直得到如下错误:

TypeError: can't multiply sequence by non-int of type 'float'

我想知道这样做的正确方法是什么?谢谢!

1 个答案:

答案 0 :(得分:1)

使用numpy broadcastingdocs

c = np.array(b.values.tolist()) * a[:,np.newaxis])
[[ 1  2  3]
 [ 8 10 12]
 [21 24 27]]

或者:

c = np.array(b.values.tolist()) * a.values.reshape(len(a),-1)
print (c)
[[ 1  2  3]
 [ 8 10 12]
 [21 24 27]]

然后:

s3 = pd.Series(c.tolist())
print (s3)
0       [1, 2, 3]
1     [8, 10, 12]
2    [21, 24, 27]
dtype: object