pandas 返回子集基于 columnA.isin.list(columnB)



我有一个这样的数据帧:

             userid  number  weight mask
0    17cf2504d0c7       1      1    56
1    17cf2504d0c7       2      5    56
2    17cf2504d0c7       3      3    123

我只是尝试返回一个子集,其中"权重"出现在数字"掩码"列表中

             userid  number  weight mask
1    17cf2504d0c7       2      5    56
2    17cf2504d0c7       3      3    123

我似乎没有使用迭代器,这似乎是对熊猫的浪费。

嗯,一种方法是将整数转换为set并使用集合减法。

mask_ = df.weight.astype(str).apply(set).sub(df['mask'].astype(str).apply(set)).str.len().eq(0)

然后

df.loc[mask_, :]

    userid          number  weight  mask
1   17cf2504d0c7    2       5       56
2   17cf2504d0c7    3       3       123

最新更新