我有一個數據框“資產”,列包括“方向”、“打開”、“關閉”和“擺動”。我想生成一個列“Break”,因此:if (((asset['Direction'] == 1) & (asset.open.shift(2) <= asset['Swing']) & (asset.close.shift(2) >= asset['Swing']) & (asset.open.shift(1) >= asset['Swing']) & (asset.close.shift(1) >= asset['Swing']) & (asset.open >= asset['Swing']) & (asset.close >= asset['Swing'])) |
((asset['Direction'] == -1) & (asset.open.shift(2) >= asset['Swing']) & (asset.close.shift(2) <= asset['Swing']) & (asset.open.shift(1) <= asset['Swing']) & (asset.close.shift(1) <= asset['Swing']) & (asset.open <= asset['Swing']) & (asset.close <= asset['Swing']))):
asset['Break'] = True但是,這會產生以下錯誤:"The truth value of a {type(self).__name__} is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all()."我以為我使用了正確的“按位”運算符來避免這種情況,但錯誤仍然存在......
1 回答

梵蒂岡之花
TA貢獻1900條經驗 獲得超5個贊
這個巨大的表達式會產生一系列布爾值。你需要按照它說的去做:決定你是否希望條件if
是“所有這些布爾值都為真”,“這些布爾值都不為真”等。
但我認為您真正想做的是將 True 分配給break
滿足條件的列。為此你應該這樣做:
asset['Break'] = ((asset['Direction'] == 1) & ...
這會將一個數組分配給一個數組,而不是像您的代碼那樣將數組與標量混淆。
添加回答
舉報
0/150
提交
取消