gto*_*mer 5 python dataframe pandas
我有一个数据框并添加了最后一行的总计。
import pandas as pd
df = pd.DataFrame({'D': {0: 6, 1: 4, 2: 6},
'A': {0: 1, 1: 2, 2: 3},
'C': {0: 2, 1: 7, 2: 5},
'B': {0: 4, 1: 5, 2: 6}})
df = df.append(df.sum(), ignore_index=True)
df
D A C B
0 6 1 2 4
1 4 2 7 5
2 6 3 5 6
3 16 6 14 15
Run Code Online (Sandbox Code Playgroud)
如何过滤,例如仅保留最后一行值(总计)高于 10 的列?预期输出:
D C B
0 6 2 4
1 4 7 5
2 6 5 6
3 16 14 15
Run Code Online (Sandbox Code Playgroud)
您可以使用选择最后一行,DataFrame.iloc然后使用Series.gt创建布尔掩码,然后使用此掩码来DataFrame.loc过滤所需的列:
df.loc[:, df.iloc[-1].gt(10)]
Run Code Online (Sandbox Code Playgroud)
D C B
0 6 2 4
1 4 7 5
2 6 5 6
3 16 14 15
Run Code Online (Sandbox Code Playgroud)