Python Pandas中布尔索引的用法详解

作者:海拥 时间:2023-11-04 08:37:45 

在布尔索引中,我们将根据 DataFrame 中数据的实际值而不是它们的行/列标签或整数位置来选择数据子集。在布尔索引中,我们使用布尔向量来过滤数据。

布尔索引是一种使用 DataFrame 中数据的实际值的索引。在布尔索引中,我们可以通过四种方式过滤数据:

  • 使用布尔索引访问 DataFrame

  • 将布尔掩码应用于数据帧

  • 根据列值屏蔽数据

  • 根据索引值屏蔽数据

使用布尔索引访问 DataFrame

为了访问具有布尔索引的数据帧,我们必须创建一个数据帧,其中数据帧的索引包含一个布尔值,即“真”或“假”。

例子

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

df = pd.DataFrame(dict, index = [True, False, True, False])

print(df)

输出: 

Python Pandas中布尔索引的用法详解

现在我们已经创建了一个带有布尔索引的数据框,之后用户可以在布尔索引的帮助下访问数据框。用户可以使用 .loc[]、.iloc[]、.ix[] 三个函数访问数据帧 

使用.loc[]访问具有布尔索引的数据框

为了使用 .loc[] 访问具有布尔索引的数据帧,我们只需在 .loc[] 函数中传递一个布尔值(True 或 False)。

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

# 使用布尔索引创建数据框
df = pd.DataFrame(dict, index = [True, False, True, False])

# 使用 .loc[] 函数访问数据框
print(df.loc[True])

输出: 

Python Pandas中布尔索引的用法详解

使用.iloc[]访问具有布尔索引的数据框

为了使用 .iloc[] 访问数据帧,我们必须传递一个布尔值(True 或 False),但 iloc[] 函数只接受整数作为参数,因此它会抛出错误,因此我们只能在我们访问数据帧时访问在 iloc[] 函数中传递一个整数 

代码#1:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

# 使用布尔索引创建数据框
df = pd.DataFrame(dict, index = [True, False, True, False])

# 使用 .iloc[] 函数访问数据帧
print(df.iloc[True])

输出:

TypeError

代码#2:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

# 使用布尔索引创建数据框
df = pd.DataFrame(dict, index = [True, False, True, False])

# 使用 .iloc[] 函数访问数据帧
print(df.iloc[1])

输出:

Python Pandas中布尔索引的用法详解

使用.ix[]访问具有布尔索引的数据框

为了使用 .ix[] 访问数据帧,我们必须将布尔值(True 或 False)和整数值传递给 .ix[] 函数,因为我们知道 .ix[] 函数是 .loc[] 的混合体和 .iloc[] 函数。 

代码#1:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

# 使用布尔索引创建数据框
df = pd.DataFrame(dict, index = [True, False, True, False])

# 使用 .ix[] 函数访问数据帧
print(df.ix[True])

输出: 

Python Pandas中布尔索引的用法详解

代码#2:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

# 使用布尔索引创建数据框
df = pd.DataFrame(dict, index = [True, False, True, False])

# 使用 .ix[] 函数访问数据帧
print(df.ix[1])

输出: 

Python Pandas中布尔索引的用法详解

将布尔掩码应用于数据框

在数据框中,我们可以应用布尔掩码。为此,我们可以使用 getitems 或 [] 访问器。我们可以通过给出与数据帧中包含的长度相同的 True 和 False 列表来应用布尔掩码。当我们应用布尔掩码时,它将仅打印我们传递布尔值 True 的数据帧。

代码#1:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["MBA", "BCA", "M.Tech", "MBA"],
'score':[90, 40, 80, 98]}

df = pd.DataFrame(dict, index = [0, 1, 2, 3])

print(df[[True, False, True, False]])

输出: 

Python Pandas中布尔索引的用法详解

代码#2: 

# importing pandas package
import pandas as pd

# 从csv文件制作数据框
data = pd.read_csv("nba1.1.csv")

df = pd.DataFrame(data, index = [0, 1, 2, 3, 4, 5, 6,
7, 8, 9, 10, 11, 12])

print(df[[True, False, True, False, True,
False, True, False, True, False,
True, False, True]])

输出: 

Python Pandas中布尔索引的用法详解

根据列值屏蔽数据

在数据框中,我们可以根据列值过滤数据。为了过滤数据,我们可以使用不同的运算符对数据框应用某些条件,例如 ==、>、<、<=、>=。当我们将这些运算符应用于数据帧时,它会产生一系列真假。

代码#1:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["BCA", "BCA", "M.Tech", "BCA"],
'score':[90, 40, 80, 98]}

# 创建数据框
df = pd.DataFrame(dict)

# 使用比较运算符过滤数据
print(df['degree'] == 'BCA')

输出: 

Python Pandas中布尔索引的用法详解

代码#2:

# importing pandas package
import pandas as pd

# 从csv文件制作数据框
data = pd.read_csv("nba.csv", index_col ="Name")

# 使用大于运算符过滤数据
print(data['Age'] > 25)

输出: 

Python Pandas中布尔索引的用法详解

根据索引值屏蔽数据: 

在数据框中,我们可以根据列值过滤数据。为了过滤数据,我们可以使用 ==、>、< 等不同的运算符根据索引值创建掩码。

代码#1:

# importing pandas as pd
import pandas as pd

# 列表字典
dict = {'name':["aparna", "pankaj", "sudhir", "Geeku"],
'degree': ["BCA", "BCA", "M.Tech", "BCA"],
'score':[90, 40, 80, 98]}

df = pd.DataFrame(dict, index = [0, 1, 2, 3])

mask = df.index == 0

print(df[mask])

输出:

Python Pandas中布尔索引的用法详解

代码#2:

# importing pandas package
import pandas as pd

# 从csv文件制作数据框
data = pd.read_csv("nba1.1.csv")

# 为数据框提供索引
df = pd.DataFrame(data, index = [0, 1, 2, 3, 4, 5, 6,
7, 8, 9, 10, 11, 12])

# 根据索引值过滤数据
mask = df.index > 7

print(df[mask])

输出: 

Python Pandas中布尔索引的用法详解

来源:https://juejin.cn/post/7137885620919074852

标签:Python,Pandas,布尔,索引
0
投稿

猜你喜欢

  • Javascript将string类型转换int类型

    2023-09-17 00:05:37
  • Python自动重新加载模块详解(autoreload module)

    2023-09-19 04:36:12
  • python实现自动登录后台管理系统

    2021-05-26 13:40:48
  • 获取CSDN文章内容并转换为markdown文本的python

    2021-04-05 08:32:15
  • 教你在SQL Server数据库中导入导出数据

    2008-12-09 14:42:00
  • python利用re,bs4,requests模块获取股票数据

    2022-05-07 05:02:23
  • 用svg制作富有动态的tooltip

    2024-04-18 10:10:42
  • sql2005 存储过程分页示例代码

    2024-01-13 03:09:06
  • matplotlib subplot绘制多个子图的方法示例

    2021-12-18 14:49:50
  • 简单的asp采集代码教程

    2011-04-18 10:39:00
  • iview实现动态表单和自定义验证时间段重叠

    2023-07-02 17:09:28
  • GoLang中的timer定时器实现原理分析

    2024-04-23 09:36:12
  • 动态程序防采集的新方法

    2010-04-24 15:24:00
  • 下拉列表两级连动的新方法(一)

    2009-06-04 18:18:00
  • 详解CentOS升级Python2.6到Python2.7并安装pip

    2023-06-13 18:59:45
  • 网站如何使用黄金分割布局

    2010-11-05 18:34:00
  • 创建SparkSession和sparkSQL的详细过程

    2023-02-13 14:40:40
  • 在python中如何建立一个自己的包

    2022-12-27 12:42:25
  • python实现Virginia无密钥解密

    2023-07-25 10:56:49
  • python matplotlib实现将图例放在图外

    2021-11-19 06:55:45
  • asp之家 网络编程 m.aspxhome.com