python基础——apply(),applymap(),map()方法的区别

2023-10-19 13:20

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

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

下面,我们定义个一个DataFrame,进行案例说明:

import pandas as pd
import numpy as np
from pandas import DataFrame
from pandas import Series
df= DataFrame({"a":[-1,2,3],"b":[3,-5,7],})

输出:

1、apply()函数

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

df.apply(lambda x:x.max()-x.min(),axis=1)  #按照行取极差。

输出:

0    4
1    7
2    4
dtype: int64

有些时候,我们发现,不用指定行/列也可以,这个时候就和applymap的用法类似了。如下:

df.apply(lambda x:x+1)

输出:

 2、applymap()函数

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

df.applymap(lambda x : 1 if x>0 else 0)

输出:

以下和apply的用法类似。

df.applymap(lambda x:x+1)

输出:

如以下我们就不能使用applymap,applymap是对df中的每个元素(int)进行计算的,int是没有max()函数的。如下:

df.applymap(lambda x:x.max()-x.min())

输出:

AttributeError: 'int' object has no attribute 'max'

同样,因为applymap是对df中的每个元素(int)进行计算的,没有通过axis指定行列这一说。如下:

df.applymap(lambda x:x.max()-x.min(),axis=1)

输出:

TypeError: applymap() got an unexpected keyword argument 'axis'

3、map()函数

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

df['a'].map(lambda x :x+ 1)

输出: 

0    0
1    3
2    4
Name: a, dtype: int64

 同样,map是对Series的每一个数据进行操作的。所以无法直接对df进行操作,如下:

df.map(lambda x :x+ 1)

输出:

AttributeError: 'DataFrame' object has no attribute 'map'

 

这篇关于python基础——apply(),applymap(),map()方法的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha