首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >pandas实现sql的case when查询,原来这么简单!

pandas实现sql的case when查询,原来这么简单!

作者头像
派大星的数据屋
发布于 2025-04-22 04:48:12
发布于 2025-04-22 04:48:12
27300
代码可运行
举报
运行总次数:0
代码可运行

sql中的case when的功能是实现单列或者多列的条件统计,其实Pandas也可以实现的,比如万能的apply方法,就是写起来复杂一些,没有sql case when那么直观。

apply方法可以对dataframe、series执行特定函数,其实很强大,因为python什么逻辑都可以写。

举个例子,一张考试成绩的表scores,有语文和数学的得分,现在给考生综合打分,两门都在90以上打A,都在80-90之间打B,其他则打C。

这里如果用sql来查询的话,使用case when就很简单明了。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT *,
        CASE
            WHEN chinese_score >= 90AND math_score >= 90THEN'A'
            WHEN chinese_score >= 80AND math_score >= 80THEN'B'
            ELSE'C'
        ENDAS score_type
    FROM scores

如果用pandas apply方法来实现的话,需要自定义一个判断函数,用来对成绩进行分类。

然后用apply方法应用到dataframe上,以下是完整代码,可以放到本地电脑跑。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pd
# 示例数据
data = {
    'chinese_score': [90, 80, 79, 100, 89],
    'math_score': [91, 95, 79, 99, 89],
}
df = pd.DataFrame(data)

# 定义条件判断函数
def check_conditions(row):
    # 条件1:年龄>30,分数>80,性别为男性
    result = 'A'if (row['chinese_score'] >= 90) and (row['math_score'] >= 90) \
            else'B'if (row['chinese_score'] >= 80) and (row['math_score'] >= 80) \
            else'C'
    return result

# 应用apply生成标记列
score_type_1 = df.apply(check_conditions, axis=1)

score_type_1

逻辑也很简单,判断函数实现多列的判断条件,apply将该判断函数应用到数据集上,就能实现类似sql case when的功能。

apply的应用场景很多,远比你想象的多得多,比如一张学生成绩信息的表,它可以给每位学生通过deepseek制定个性化的提升建议。

除了pandas apply能实现case when的功能外,numpy的select方法也能搞定,而且更为通用、简洁,建议试试。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import numpy as np
import pandas as pd
# 示例数据
data = {
    'chinese_score': [90, 80, 79, 100, 89],
    'math_score': [91, 95, 79, 99, 89],
}
df = pd.DataFrame(data)

# 定义条件和对应的值
conditions = [
 (df['chinese_score'] >= 90) & (df['math_score'] >= 90),
 (df['chinese_score'] >= 80) & (df['math_score'] >= 80)
]
choices = ['A', 'B']

# select方法
score_type_1 = np.select(conditions, choices, default='C')
score_type_1

numpy select方法类似case when语法,通过一个多列条件判断,区分不同的分类。

除了这两种,其实pandas种还有不少能实现的途径,但没必要尝试,因为这两种相对通用便捷,且符合python哲学。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-04-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python大数据分析 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验