首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何通过一列中的值在另一列中多次映射来提取数据?

如何通过一列中的值在另一列中多次映射来提取数据?
EN

Stack Overflow用户
提问于 2020-06-10 20:49:56
回答 1查看 22关注 0票数 0

我有如下数据帧:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Data    Items   Key
SD1     ABX2    9
SD2     ABX2    10
SD3     ABX2    23
SD1     CAB2    sd
SD1     ABX2    km
SD1     CAB2    kj
SD5     TND     lo
SD9     TNK     gf
SD7     SDK     bf
SD11    CAB2    lo
SD1     TND     78
SD3     TND     nm

我希望根据Items列中的值进行过滤,该列至少可以在三个不同的Data中找到。预期输出为:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Data    Items   Key
SD1     ABX2    9
SD2     ABX2    10
SD3     ABX2    23
SD1     ABX2    km
SD5     TND     lo
SD1     TND     78
SD3     TND     nm
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-10 20:52:44

您可以使用groupby().transform('nunique')计算每个项目出现的数据数量,然后使用布尔索引进行筛选:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
df[df.groupby('Items').Data.transform('nunique')>=3]

输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
   Data Items Key
0   SD1  ABX2   9
1   SD2  ABX2  10
2   SD3  ABX2  23
4   SD1  ABX2  km
6   SD5   TND  lo
10  SD1   TND  78
11  SD3   TND  nm
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62312873

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文