根据最后一行值过滤列

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)

Shu*_*rma 6

您可以使用选择最后一行,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)