一日一技:从列表中一次性筛选多个指定位置的数据


Pandas的DataFrame在筛选列数据的时候,有一个非常方便的用法。

假设现在有这样一个DataFrame:

import pandas as pd
data = [
    {'name': 'kingname', 'age': 20, 'salary': 99999},
    {'name': 'alice', 'age': 30, 'salary': 99999},
    {'name': 'bob', 'age': 10, 'salary': 99999},
    {'name': 'cindy', 'age': 40, 'salary': 99999}
]
df = pd.DataFrame(data)
df

运行效果如下图所示:

我要筛选所有 age>=30的数据,可以这样写:

df[df['age'] >= 30]

运行效果如下图所示:

而这里面的原理,实际上可以使用下面这个代码来解释:

df[[False, True, False, True]]

如下图所示:

那么问题来了,我有一个Python里面,列表能不能也实现这个功能呢?假设有下面两个列表:

name_list = ['kingname', 'alice', 'bob', 'cindy']
position_list = [True, False, True, False]

我想把 position_list列表中, True的下标在 name_list中对应的值都获取下来。

你可能会这样写代码:

name_list = ['kingname', 'alice', 'bob', 'cindy']
position_list = [True, False, True, False]
for name, position in zip(name_list, position_list):
    if position:
        print(name)

运行效果如下图所示:

但实际上,在Python里面有一个现成的函数可以实现这个功能,那就是 itertools.compress(),其使用方法如下:

from itertools import compress
name_list = ['kingname', 'alice', 'bob', 'cindy']
position_list = [True, False, True, False]
for name in compress(name_list, position_list):
    print(name)

运行效果如下图所示:

大家好,我是老表
觉得本文不错的话,转发、留言、点赞,是对我最大的支持。

每日留言

说说你读完本文感受?

或者一句激励自己的话?

(字数不少于15字)

怎么加入刻意学习队伍

点我,看文末彩蛋

留言有啥福利

点我就知道了

想进学习交流群

加微信:jjxksa888

:简说Python

2小时快速掌握Python基础知识要点

完整Python基础知识要点

Python小知识 | 这些技能你不会?(一)

Python小知识 | 这些技能你不会?(二)

Python小知识 | 这些技能你不会?(三)

Python小知识 | 这些技能你不会?(四)

近期推荐阅读:

【1】整理了我开始分享学习笔记到现在超过250篇优质文章,涵盖数据分析、爬虫、机器学习等方面,别再说不知道该从哪开始,实战哪里找了

【2】【终篇】Pandas中文官方文档:基础用法6(含1-5)

觉得不错就点一下“在看”吧 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值