Pandas中的map(), apply()和applymap()的区别

2024-01-21 03:48
文章标签 区别 apply map pandas applymap

本文主要是介绍Pandas中的map(), apply()和applymap()的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

将一个自定义的函数应用到Pandas的数据结构中可以使用map(), apply()或者applymap(),它们的区别在于应用的对象不同。

apply()和applymap()是DataFrame结构中的函数,Series中没有。它们的区别在于,apply()将一个函数作用于DataFrame中的每个行或者列,而applymap()是将函数做用于DataFrame中的所有元素(elements)。

apply() 当想让方程作用在一维的向量上时,可以使用apply来完成
Python
In [6]: from <span class="wp_keywordlink_affiliate"><a href="https://www.168seo.cn/tag/pandas" title="View all posts in pandas" target="_blank">pandas</a></span> import DataFrame In [7]: import numpy as np In [8]: frame = DataFrame(np.random.randn(4, 3), columns=list('bde'), index=['Ut ...: ah', 'Ohio', 'Texas', 'Oregon']) In [9]: frame Out[9]: b d e Utah 1.646124 -0.843271 -0.253782 Ohio -0.965261 0.254368 -0.173054 Texas -0.927661 -0.558319 -0.838144 Oregon -1.410459 -1.901251 1.199630 In [10]: f = lambda x: x.max() - x.min() In [11]: frame.apply(f) Out[11]: b 3.056583 d 2.155619 e 2.037774 dtype: float64
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
In [ 6 ] : from pandas import DataFrame
In [ 7 ] : import numpy as np
In [ 8 ] : frame = DataFrame ( np . random . randn ( 4 , 3 ) , columns = list ( 'bde' ) , index = [ 'Ut
...: ah' , 'Ohio' , 'Texas' , 'Oregon' ] )
In [ 9 ] : frame
Out [ 9 ] :
b d e
Utah 1.646124 - 0.843271 - 0.253782
Ohio - 0.965261 0.254368 - 0.173054
Texas - 0.927661 - 0.558319 - 0.838144
Oregon - 1.410459 - 1.901251 1.199630
In [ 10 ] : f = lambda x : x . max ( ) - x . min ( )
In [ 11 ] : frame . apply ( f )
Out [ 11 ] :
b 3.056583
d 2.155619
e 2.037774
dtype : float64
map()只要是作用将函数作用于一个Series的每一个元素,用法如下所示

map() 是一个Series的函数,DataFrame结构中没有map()。map()将一个自定义函数应用于Series结构中的每个元素(elements)。

Python
In [122]: frame['e'].map(format) Out[122]: Utah 1.28 Ohio -1.55 Texas 0.20 Oregon -0.31 Name: e, dtype: object
1
2
3
4
5
6
7
8
In [ 122 ] : frame [ 'e' ] . map ( format )
Out [ 122 ] :
Utah 1.28
Ohio - 1.55
Texas 0.20
Oregon - 0.31
Name : e , dtype : object

applymap()如果想让方程作用于DataFrame中的每一个元素,可以使用applymap().用法如下所示

Python
In [120]: format = lambda x: '%.2f' % x In [121]: frame.applymap(format) Out[121]: b d e Utah -0.03 1.08 1.28 Ohio 0.65 0.83 -1.55 Texas 0.51 -0.88 0.20 Oregon -0.49 -0.48 -0.31
1
2
3
4
5
6
7
8
9
10
In [ 120 ] : format = lambda x : '%.2f' % x
In [ 121 ] : frame . applymap ( format )
Out [ 121 ] :
b d e
Utah - 0.03 1.08 1.28
Ohio 0.65 0.83 - 1.55
Texas 0.51 - 0.88 0.20
Oregon - 0.49 - 0.48 - 0.31



  • zeropython 微信公众号 5868037 QQ号 5868037@qq.com QQ邮箱

这篇关于Pandas中的map(), apply()和applymap()的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628289

相关文章

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

Java 关键字transient与注解@Transient的区别用途解析

《Java关键字transient与注解@Transient的区别用途解析》在Java中,transient是一个关键字,用于声明一个字段不会被序列化,这篇文章给大家介绍了Java关键字transi... 在Java中,transient 是一个关键字,用于声明一个字段不会被序列化。当一个对象被序列化时,被

解读@ConfigurationProperties和@value的区别

《解读@ConfigurationProperties和@value的区别》:本文主要介绍@ConfigurationProperties和@value的区别及说明,具有很好的参考价值,希望对大家... 目录1. 功能对比2. 使用场景对比@ConfigurationProperties@Value3. 核

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失