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

栏目: Python · 发布时间: 6年前

内容简介:Pandas的DataFrame在筛选列数据的时候,有一个非常方便的用法。假设现在有这样一个DataFrame:运行效果如下图所示:

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)
复制代码

运行效果如下图所示:

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

如果这篇文章对你有帮助,请关注我的微信公众号: 未闻Code(ID: itskingname),第一时间获的最新更新:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人人时代

人人时代

[美]克莱•舍基(Clay Shirky) / 胡泳、沈满琳 / 中国人民大学出版社 / 2012-8 / 49.90元

[内容简介] •一而再,再而三出现的公众事件,绝不仅是来自草根的随兴狂欢,而是在昭示着一种变革未来的力量之崛起!基于爱、正义、共同的喜好和经历,人和人可以超越传统社会的种种限制,灵活而有效地采用即时通信、移动电话、网络日志和维基百科等新的社会性工具联结起来,一起分享、合作乃至展开集体行动。人人时代已经到来。 •微软、诺基亚、宝洁、BBC、乐高、美国海军最推崇的咨询顾问,“互联网革命最伟......一起来看看 《人人时代》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

SHA 加密
SHA 加密

SHA 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器