pandas使用apply函数处理数据

pandas处理数据中常用的一种处理数据的方式是使用apply函数
会使数据处理起来更快更简单
可以进行单列 或者多列
单列
在这里插入图片描述
现在想根据他的月总业绩,进行分等级,并且命名为等级,等级有[‘A’,‘B’,‘C’,‘D’,‘E’,‘F’]

from pandas import read_excel
data = read_excel('yeji.xlsx')
# 自定义函数
# 因为只会用到一列,所以函数参数只有一列
def cut_level(x):
	if x < 1200:
        return 'F'
    elif x < 5000:
        return 'E'
    elif x < 20000:
        return 'D'
    elif x < 100000:
        return 'C'
    elif x < 250000:
        return 'B'
    else:
        return 'A'
data['等级'] = data['月总业绩'].apply(cut_to)
print(data)

在这里插入图片描述
对于多列
现在等级出来了 我们需要返回一个比列,数据纯属捏造,只为了方便

# 对于多列
# 根据月总业绩,等级划分一列比例
# 因为是根据两列 所以函数传入参数2个。需要根据几列进行判断,函数就传入几个参数
def cut_to(x, y):
	if x > 200000 and y == 'A':
		return 0.8
	elif x > 100000 and y == 'B':
		return 0.6
	elif x > 50000 and y == 'B':
		return 0.5
	else:
		return 0.4
data['比例'] = data.apply(lambda row: cut_to(row['月总业绩'], row['等级'],axis=1)
data	

在这里插入图片描述

### 如何使用 `apply` 函数处理 Pandas 数据框 #### 应用于整个数据框的行或列 Pandas 的 `apply` 函数允许使用者通过指定轴参数来决定是在行还是列上执行函数。当目标是对每行或每列应用相同的逻辑时,此方法非常有用[^1]。 对于行操作而言,可以通过设置 `axis=1` 参数实现;而针对列的操作则保持默认值 `axis=0` 或者不传入该参数即可。下面是一个简单的例子展示如何计算学生各科目的总成绩: ```python import pandas as pd data = { '数学': [90, 80, 85], '英语': [95, 70, 88], '科学': [85, 90, 80] } df = pd.DataFrame(data) def total_score(row): return row.sum() df['总成绩'] = df.apply(total_score, axis=1) print(df) ``` 这段代码创建了一个包含三门课程成绩的数据框,并定义了一个名为 `total_score` 的函数用来求和每一行的成绩。最后利用 `apply()` 将这个函数应用于所有行并保存结果至新列 `'总成绩'` 中[^2]。 #### 单独对某一系列(Series)应用函数 除了在整个数据框层面调用外,还可以直接在一个 Series 上面使用 `apply` 方法来进行更加精细的操作。比如根据条件给定额外加分的情况可以这样写: ```python import pandas as pd # 假设已经读取了 CSV 文件中的数据到 df 变量里 df['ExtraScore'] = df['Nationality'].apply(lambda x: 5 if x != '汉' else 0) df['TotalScore'] = df['Score'] + df['ExtraScore'] ``` 这里展示了怎样基于国籍字段判断是否给予额外分数,并将其加入原始得分之中形成新的总计分列[^4]。 #### 自定义复杂业务逻辑 有时候需要实现更为复杂的业务需求,这时就可以借助 Python 的强大表达能力来自由构建所需的算法流程。例如,在某些情况下可能希望引入外部库以提高效率或是简化代码结构。不过需要注意的是,在追求灵活性的同时也要考虑到性能方面的影响,合理权衡两者之间的系[^5]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vergil_Zsh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值