cry*_*ryp 2 python dataframe pandas
我有两个数据框,我想将它们乘以索引.最好的方法是什么?注意:列名称不同.
df1 = pd.DataFrame([(1,2,3),(3,4,5),(5,6,7)], columns=['a','b','d'], index = ['A', 'B','C'])
df1
a b d
A 1 2 3
B 3 4 5
C 5 6 7
df2 = pd.DataFrame([(10,20,30)], columns=['A','B','C'],index = ['ss'])
df2 = df2.transpose()
df2
ss
A 10
B 20
C 30
Run Code Online (Sandbox Code Playgroud)
输出数据帧:
a b d
A 10 20 30
B 60 80 100
C 150 180 210
Run Code Online (Sandbox Code Playgroud)
调用mul并将Series转换为列表并传递axis=0,通过转换为列表,我们忽略索引/列名称的任何对齐错误:
In [74]:
df1.mul(list(df2['ss']), axis=0)
Out[74]:
a b d
A 10 20 30
B 60 80 100
C 150 180 210
Run Code Online (Sandbox Code Playgroud)
编辑
无需转换为列表即可直接访问Series:
In [75]:
df1.mul(df2['ss'], axis=0)
Out[75]:
a b d
A 10 20 30
B 60 80 100
C 150 180 210
Run Code Online (Sandbox Code Playgroud)