11
を合計:Pythonのパンダの条件は、サンプルデータを使用して
df = pd.DataFrame({'key1' : ['a','a','b','b','a'],
'key2' : ['one', 'two', 'one', 'two', 'one'],
'data1' : np.random.randn(5),
'data2' : np. random.randn(5)})
DF
data1 data2 key1 key2
0 0.361601 0.375297 a one
1 0.069889 0.809772 a two
2 1.468194 0.272929 b one
3 -1.138458 0.865060 b two
4 -0.268210 1.250340 a one
私は「KEY1と和によってどのグループにKEY2に等しいだけDATA1値をデータを把握しようとしています1'。ここで
は私が
def f(d,a,b):
d.ix[d[a] == b, 'data1'].sum()
df.groupby(['key1']).apply(f, a = 'key2', b = 'one').reset_index()
しようとしたものだ。しかし、これは私に 'なし' はここ
index key1 0
0 a None
1 b None
任意のアイデア値はありませんとのデータフレームを与えますか?私は、次のSQLのパンダと同等を探しています:
SELECT Key1, SUM(CASE WHEN Key2 = 'one' then data1 else 0 end)
FROM df
GROUP BY key1
をFYI - 私はconditional sums for pandas aggregateを見てきましたが、合計ではなく、数で動作するように設け答えを変換することができませんでした。事前に
おかげ
すごいです!私は実際のデータにこれを試しています(しばらく時間がかかるかもしれません)が、これは私が探していたものだと思います。ありがとうございました – AllenQ
私はここで新しいgroupbyフィルターを使うことができると思います... – Jeff
ドキュメントとすばやいグーグル検索を検索しました...あなたがgroupbyフィルターによって参照しているものを正確に見つけることができませんでした。あなたは正しい方向に私を向ける? – AllenQ