python 如何在列表、字典、集合中根据条件筛选数据--实战经验

一、列表

需求:过滤掉列表中的负数数据

复制代码
from random import randint
#生成数据
data = [randint(-10,10) for _ in range(10)]
复制代码
[-6, -10, -6, -9, -7, -7, 2, -9, 9, 2]

第一种,传统的方法

复制代码
res=[]
for x in data:
    if x>=0:
        res.append(x)

第二种,filter方法

复制代码
list(filter(lambda x:x>=0,data))
#[2, 9, 2]

第三种,列表解析

复制代码
[x for x in data if x>=0]
#[2, 9, 2]

总结:无论是运行速度还是代码容易理解程度,列表解析最好用。

二、字典,筛选出字典里超过90分的数据

随机生成数据:

复制代码
d = {f'{x}号':randint(60,100) for x in range(1,21)}
{
'1号': 92,
 '2号': 85,
 '3号': 85,
 '4号': 68,
 '5号': 86,
 '6号': 81,
 '7号': 70,
 '8号': 65,
 '9号': 86,
 '10号': 85,
 '11号': 86,
 '12号': 60,
 '13号': 94,
 '14号': 70,
 '15号': 89,
 '16号': 69,
 '17号': 71,
 '18号': 83,
 '19号': 60,
 '20号': 74
}

字典列表解析

复制代码
{k:v for k,v in d.items() if v>90}
#{'1号': 92, '13号': 94}

三、集合解析

复制代码
{-10, -9, -7, -6, 2, 9} 

要求过滤能被3整除的集合

复制代码
{x for x in s if x%3==0}
相关推荐
weixin_5806140017 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_8135995517 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
李可以量化17 小时前
QMT 量化实战:用 Python 实现线性回归通道,精准识别趋势中的支撑与压力(下)
python·qmt·量化 qmt ptrade
a95114164218 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
Dxy123931021618 小时前
Python 使用正则表达式将多个空格替换为一个空格
开发语言·python·正则表达式
qq_1898070318 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
zhangchaoxies18 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
Luca_kill18 小时前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
zhangchaoxies19 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
故事和你9119 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论