网站首页 > 技术文章 正文
sql中的case when的功能是实现单列或者多列的条件统计,其实Pandas也可以实现的,比如万能的apply方法,就是写起来复杂一些,没有sql case when那么直观。
apply方法可以对dataframe、series执行特定函数,其实很强大,因为python什么逻辑都可以写。
举个例子,一张考试成绩的表scores,有语文和数学的得分,现在给考生综合打分,两门都在90以上打A,都在80-90之间打B,其他则打C。
这里如果用sql来查询的话,使用case when就很简单明了。
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上,以下是完整代码,可以放到本地电脑跑。
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方法也能搞定,而且更为通用、简洁,建议试试。
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-07-27 Python 3.14 新特性盘点,更新了些什么?
- 2025-07-27 Python单元测试(pycharm单元测试教程)
- 2025-07-27 Python学不会来打我(8)字符串string类型深度解析
- 2025-07-27 Python 中 字符串处理的高效方法,不允许你还不知道
- 2025-07-27 Python-分支结构(python分支结构教学设计)
- 2025-07-27 python学习教程-第六节内容(python基础教学视频)
- 2025-07-27 Python自动化办公应用学习笔记16——分支结构
- 2025-05-05 python unittest 基本用法(python3 unittest)
- 2025-05-05 使用pytest进行单元测试(pytest详解)
- 2025-05-05 用扣子开发一个图灵测试游戏(用扣子开发一个图灵测试游戏的软件)
- 08-06中等生如何学好初二数学函数篇
- 08-06C#构造函数
- 08-06初中数学:一次函数学习要点和方法
- 08-06仓颉编程语言基础-数据类型—结构类型
- 08-06C++实现委托机制
- 08-06初中VS高中三角函数:从"固定镜头"到"360°全景",数学视野升级
- 08-06一文讲透PLC中Static和Temp变量的区别
- 08-06类三剑客:一招修改所有对象!类方法与静态方法的核心区别!
- 1524℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 663℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 531℃MySQL service启动脚本浅析(r12笔记第59天)
- 494℃启用MySQL查询缓存(mysql8.0查询缓存)
- 493℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 481℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 463℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 461℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (70)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)