盘点一道Pandas处理多个关键词搜索的实战问题

IT共享之家

共 1084字,需浏览 3分钟

 · 2022-07-10

点击上方“Python共享之家”,进行关注

回复“资源”即可获赠Python学习资料

永怀当此节,倚立自移时。

大家好,我是皮皮。

一、前言

前几天在Python铂金交流群粉丝【dcpeng】问了一道Pandas处理的问题,如下图所示。

原始数据,如下所示:

他自己写了一个代码,如下所示:

def search(x):
    a = dfs3.loc[dfs3['项目名称'].str.contains(x)]
    return a
search('界面剂')

后来虽然确实也勉强写出来了,如下图所示:

但是希望有更好的方法!

二、实现过程

这里【月神】给了一份优化代码,如下所示:

def search(search_list: list):
    search_str = f"({'|'.join(search_list)})"
    return df[df['项目名称'].str.extractall(search_str).groupby(level=0)[0].nunique() >= len(search_list)]

search(['界面剂''水泥砂浆''刮糙'])

【月神】使用Pandas完美地解决了粉丝的问题,简直天秀。

三、总结

大家好,我是皮皮。这篇文章主要盘点了一道Pandas处理数据的问题,文中针对该问题给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【dcpeng】提问,感谢【月神】给出的思路和代码解析,感谢群友们一起参与学习交流。

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

------------------- End -------------------

往期精彩文章推荐:

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【

万水千山总是情,点个【在看】行不行

浏览 31
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报