apply,applymap和map的应用

apply,applymap和map的应用
总结:

apply 用在dataframe上,用于对row或者column进行计算;

applymap 用于dataframe上,是元素级别的操作;

map (其实是python自带的)用于series上,是元素级别的操作。

在Python中如果想要对数据使用函数,可以借助apply(),applymap(),map() 来应用函数,括号里面可以是直接函数式,或者自定义函数(def)或者匿名函数(lambad)


 
 
  1. import pandas as pd
  2. import numpy as np
  3. from pandas import DataFrame
  4. from pandas import Series
  5. df1= DataFrame({
  6. "sales1":[ -1, 2, 3],
  7. "sales2":[ 3, -5, 7],
  8. })
  9. df1

1、当我们要对数据框(DataFrame)的数据进行按行或按列操作时用apply()


 
 
  1. df1.apply( lambda x :x.max()-x.min(),axis= 1)
  2. #axis=1,表示按行对数据进行操作
  3. #从下面的结果可以看出,我们使用了apply函数之后,系统自动按行找最大值和最小值计算,每一行输出一个值
0    4
1    7
2    4
dtype: int64

 
 
  1. df1.apply( lambda x :x.max()-x.min(),axis= 0)
  2. #默认参数axis=0,表示按列对数据进行操作
  3. #从下面的结果可以看出,我们使用了apply函数之后,系统自动按列找最大值和最小值计算,每一列输出一个值
sales1     4
sales2    12
dtype: int64

2、当我们要对数据框(DataFrame)的每一个数据进行操作时用applymap(),返回结果是DataFrame格式


 
 
  1. df1.applymap( lambda x : 1 if x> 0 else 0)
  2. #从下面的结果可以看出,我们使用了applymap函数之后,
  3. #系统自动对每一个数据进行判断,判断之后输出结果

3、当我们要对Series的每一个数据进行操作时用map()


 
 
  1. df1.sales1.map( lambda x : 1 if x> 0 else 0)
  2. #df1.sales1就是一个Series
0    0
1    1
2    1
Name: sales1, dtype: int64

4、总结:要对数据进行应用函数时,先看数据结构是DataFrame还是Series,Seriesj结构直接用map(),DataFrame结构的话再看是要按行还是按列进行操作来选择对应的函数即可~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值