五种方法,使用python筛选出某个属性值在某两个数值之间的数据框(代码实战)

方法一:使用pandas库的条件筛选

代码:

import pandas as pd

# 创建一个示例数据框
data = {'Name': ['Tom', 'Nick', 'John', 'Amy'],
        'Age': [25, 30, 35, 40],
        'Salary': [5000, 6000, 7000, 8000]}
df = pd.DataFrame(data)

# 使用条件筛选
filtered_df = df[(df['Salary'] > 5500) & (df['Salary'] < 7500)]
print(filtered_df)

最终结果:

方法二:使用numpy库的条件筛选 

代码:

import numpy as np

# 创建一个示例数据框
data = {'Name': ['Tom', 'Nick', 'John', 'Amy'],
        'Age': [25, 30, 35, 40],
        'Salary': [5000, 6000, 7000, 8000]}
df = pd.DataFrame(data)

# 使用条件筛选
filtered_df = df[np.logical_and(df['Salary'] > 5500, df['Salary'] < 7500)]
print(filtered_df)

最终结果:

方法三:使用列表推导式筛选 

代码:

# 创建一个示例数据框
data = {'Name': ['Tom', 'Nick', 'John', 'Amy'],
        'Age': [25, 30, 35, 40],
        'Salary': [5000, 6000, 7000, 8000]}
df = pd.DataFrame(data)

# 使用列表推导式筛选
filtered_df = pd.DataFrame([row for index, row in df.iterrows() if 5500 < row['Salary'] < 7500])
print(filtered_df)

最终结果: 

 方法四:使用apply函数筛选

代码:

# 创建一个示例数据框
data = {'Name': ['Tom', 'Nick', 'John', 'Amy'],
        'Age': [25, 30, 35, 40],
        'Salary': [5000, 6000, 7000, 8000]}
df = pd.DataFrame(data)

# 使用apply函数筛选
filtered_df = df[df.apply(lambda row: 5500 < row['Salary'] < 7500, axis=1)]
print(filtered_df)

最终结果: 

 方法五:使用query函数筛选

代码:

# 创建一个示例数据框
data = {'Name': ['Tom', 'Nick', 'John', 'Amy'],
        'Age': [25, 30, 35, 40],
        'Salary': [5000, 6000, 7000, 8000]}
df = pd.DataFrame(data)

# 使用query函数筛选
filtered_df = df.query('5500 < Salary < 7500')
print(filtered_df)

最终结果:

  • 14
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值