2
我想用Python中的1X7數據框乘以10X7 Pandas數據框。Python Pandas - n X m DataFrame乘以1 X m Dataframe
以下是我有:
df = pd.DataFrame(np.random.rand(10,7),columns=list('ABCDEFG'))
df_1 = pd.DataFrame(np.random.rand(1,7),columns=list('ABCDEFG'))
我嘗試這樣做:
df_prod = pd.DataFrame(columns=df)
for i in range(0, df.shape[0]):
df_prod.iloc[i,:] = df[i,:].tolist()*df_1.iloc[0,:].tolist()
但我收到此錯誤信息:
Traceback (most recent call last):
File "C:\Python27\test.py", line 29, in <module>
df_elem.iloc[i,:] = df_val[i,:].tolist()*df_cf.iloc[0,:].tolist()
File "C:\python27\lib\site-packages\pandas\core\frame.py", line 1678, in __getitem__
return self._getitem_column(key)
File "C:\python27\lib\site-packages\pandas\core\frame.py", line 1685, in _getitem_column
return self._get_item_cache(key)
File "C:\python27\lib\site-packages\pandas\core\generic.py", line 1050, in _get_item_cache
res = cache.get(item)
TypeError: unhashable type
我要乘的所有行df
df_1
。
我需要:
df.iloc[0,:] * df_1
df.iloc[1,:] * df_1
df.iloc[2,:] * df_1
df.iloc[3,:] * df_1
.
.
.
.
df.iloc[9,:] * df_1
有沒有一種簡單的方法來實現這個乘法這在Python?
謝謝。我在Pandas文檔中尋找這樣的東西,但我找不到它。很好的答案! –