Pandas库学习之DataFrame.replace()函数

Pandas库学习之DataFrame.replace()函数

一、简介

DataFrame.replace()函数用于替换DataFrame中的指定值。该函数允许使用单个值、列表、字典或正则表达式进行替换操作,非常灵活。

二、语法和参数

python 复制代码
DataFrame.replace(to_replace=None, value=None, inplace=False, limit=None, regex=False, method='pad')
  • to_replace :需要替换的值,可以是单个值、列表、字典或正则表达式
  • value:替换后的值,可以是单个值、列表或字典。
  • inplace:布尔值,是否在原DataFrame上进行替换,默认False。
  • limit:整数,限制替换的数量。
  • regex :布尔值,是否将to_replace作为正则表达式处理,默认False。
  • method :当to_replace是NA值时,指定填充方法,如'pad'、'ffill'、'bfill'。

三、实例

3.1 替换单个值
python 复制代码
import pandas as pd

data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# 替换值
df.replace(1, 10, inplace=True)
print(df)

输出:

复制代码
    A  B
0  10  4
1   2  5
2   3  6
3.2 使用字典替换值
python 复制代码
import pandas as pd

data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# 使用字典替换值
df.replace({'A': 1, 'B': 4}, 100, inplace=True)
print(df)

输出:

复制代码
     A    B
0  100  100
1    2    5
2    3    6
3.3 使用列表替换值
python 复制代码
import pandas as pd

data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# 使用列表替换值
df.replace([1, 4], [100, 400], inplace=True)
print(df)

输出:

复制代码
     A    B
0  100  400
1    2    5
2    3    6
3.4 使用正则表达式替换值
python 复制代码
import pandas as pd

data = {'A': ['foo', 'bar', 'baz'], 'B': ['fuz', 'buz', 'faz']}
df = pd.DataFrame(data)

# 使用正则表达式替换值
df.replace(to_replace=r'^b', value='new', regex=True, inplace=True)
print(df)

输出:

复制代码
     A    B
0  foo  fuz
1  new  newz
2  new  faz

四、注意事项

  1. 当使用inplace=True时,DataFrame会直接修改,无需重新赋值。
  2. to_replace为字典时,value的值必须与to_replace的键相对应。
  3. 使用正则表达式时,需将regex参数设置为True。
相关推荐
AI成长日志20 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
小手指动起来21 小时前
保姆级提示词工程学习总结(含实操示例+工具推荐)
人工智能·学习·自然语言处理
绛橘色的日落(。・∀・)ノ21 小时前
Matplotlib实践学习笔记
笔记·学习
chase。21 小时前
【学习笔记】AGILE:把人形机器人强化学习从“玄学”变成“工程学”
笔记·学习·敏捷流程
bu_shuo21 小时前
git练习学习网站【中文网站】
git·学习
EnglishJun1 天前
ARM嵌入式学习(十四)--- IMX6ULL的I2C通信实现
arm开发·学习
_李小白1 天前
【OSG学习笔记】Day 31: 渲染到纹理(RTT)
笔记·数码相机·学习
嵌入式小企鹅1 天前
蓝牙学习系列(七):BLE GATT 数据模型详解
学习·蓝牙·ble·蓝牙协议栈·蓝牙开发·gatt
书到用时方恨少!1 天前
Python Pandas 使用指南:数据分析的瑞士军刀
python·数据分析·pandas
arvin_xiaoting1 天前
OpenClaw学习总结_III_自动化系统_3:CronJobs详解
数据库·学习·自动化