Pandas DataFrame 列的向量化操作:获取满足条件的患者列表

碧海醫心
发布: 2025-11-17 12:14:04
原创
458人浏览过

pandas dataframe 列的向量化操作:获取满足条件的患者列表

本文介绍了如何利用 Pandas DataFrame 的向量化操作,高效地获取每列中数值大于等于 0.5 的患者列表。通过列表推导式和布尔索引,避免了显式循环,提高了代码的执行效率和可读性。掌握这些技巧,可以更便捷地进行数据分析和处理。

在数据分析中,经常需要根据DataFrame中特定列的值来筛选或提取相关信息。Pandas 提供了强大的向量化操作,可以避免使用循环,从而提高效率。本文将介绍如何使用向量化操作,从DataFrame中获取每列满足特定条件的患者列表。

核心思路

核心思路是利用Pandas的布尔索引和列表推导式。首先,使用布尔索引筛选出每列中大于等于 0.5 的行。然后,从筛选后的行中提取对应的患者 ID。最后,使用列表推导式对所有列重复此操作,生成一个包含所有列的患者列表的列表。

具体步骤

  1. 准备数据

首先,创建一个示例 DataFrame,包含患者 ID 和一些数值列:

飞书多维表格
飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

飞书多维表格 26
查看详情 飞书多维表格
import pandas as pd

columns = ['S1', 'S2', 'S3', 'S4', 'S5']

df = pd.DataFrame({'Patient':['p1', 'p2', 'p3', 'p4', 'p5', 'p6', 'p7', 'p8', 'p9', 'p10'],
                   'S1':[0.7, 0.3, 0.5, 0.8, 0.9, 0.1, 0.9, 0.2, 0.6, 0.3],
                   'S2':[0.2, 0.3, 0.5, 0.4, 0.9, 0.1, 0.9, 0.7, 0.4, 0.3],
                   'S3':[0.6, 0.3, 0.5, 0.8, 0.9, 0.8, 0.9, 0.3, 0.6, 0.3],
                   'S4':[0.2, 0.3, 0.7, 0.8, 0.9, 0.1, 0.9, 0.7, 0.3, 0.3 ],
                   'S5':[0.9, 0.8, 0.5, 0.8, 0.9, 0.7, 0.2, 0.7, 0.6, 0.3 ]})

print(df)
登录后复制
  1. 使用列表推导式和布尔索引

使用列表推导式,对每一列执行以下操作:

  • 使用 df[col] >= 0.5 创建一个布尔 Series,指示每行是否满足条件。
  • 使用布尔 Series 作为索引,筛选出 DataFrame 中满足条件的行。
  • 从筛选后的 DataFrame 中提取 'Patient' 列的值,并将其转换为列表。
patient_lists = [df.Patient[df[col] >= 0.5].to_list() for col in columns]

print(patient_lists)
登录后复制
  1. 结果

patient_lists 将是一个包含多个列表的列表,每个列表对应 DataFrame 的一列,包含该列中数值大于等于 0.5 的患者 ID。

[['p1', 'p3', 'p4', 'p5', 'p7', 'p9'], 
 ['p3', 'p5', 'p7', 'p8'], 
 ['p1', 'p3', 'p4', 'p5', 'p6', 'p7', 'p9'], 
 ['p3', 'p4', 'p5', 'p7', 'p8'], 
 ['p1', 'p2', 'p3', 'p4', 'p5', 'p6', 'p9', 'p8']]
登录后复制

注意事项

  • 确保 DataFrame 中要进行比较的列是数值类型。
  • 可以根据实际需求修改条件 df[col] >= 0.5,例如使用 df[col] > value,df[col] == value 等。
  • 如果需要去重,可以将 to_list() 替换为 unique().tolist()。

总结

通过使用 Pandas 的向量化操作,可以高效地从 DataFrame 中提取满足条件的患者列表。这种方法避免了显式循环,提高了代码的执行效率和可读性。掌握这些技巧,可以更便捷地进行数据分析和处理。

以上就是Pandas DataFrame 列的向量化操作:获取满足条件的患者列表的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号