首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何按一列多列3个条件分组

如何按一列多列3个条件分组
EN

Stack Overflow用户
提问于 2019-06-04 04:00:44
回答 1查看 23关注 0票数 -1

我有dataframe,我需要申请下面的条件

  1. 检查colA是否>0
  2. 如果是,请在colB中搜索字符串"recycled“,然后比较它是否出现在colC
  3. 中如果满足,则其true else false

数据帧:

代码语言:javascript
复制
     Temp       colA     colB             colC

     ob1        50       HDP              HDP
     ob1        50       HDP recycled     HDP
     ob1        50       HDP              HDP
     ob2        0        PE               PE
     ob2        0        PE               PE
     ob3        30       PE recycled      PE recycled
     ob3        30       PE               PE recycled

输出:

代码语言:javascript
复制
     Temp       colA     colB             colC           output
     ob1        50       HDP recycled     HDP            Anomaly
     ob2        0        PE               PE             Pass
     ob3        30       PE recycled      PE recycled    Pass

我尝试过的代码:

代码语言:javascript
复制
     f=pp.groupby('Temp')['colB'].apply(lambda x: 
     x.str.contains('Recycled').any()).map({True:'Pass',False:'anomaly'})
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-04 05:33:30

尝试使用Rank函数

代码语言:javascript
复制
data['Rank'] = data.groupby('Temp')['output'].rank(method='dense',ascending=True)
data['Final'] = data.groupby('Temp')['Rank'].rank(method='first',ascending=True)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56433820

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档