【Pandas】pandas DataFrame rsub

Pandas2.2 DataFrame

Binary operator functions

方法 描述
DataFrame.add(other) 用于执行 DataFrame 与另一个对象(如 DataFrame、Series 或标量)的逐元素加法操作
DataFrame.add(other, axis, level, fill_value) 用于执行 DataFrame 与另一个对象(如 DataFrame、Series 或标量)的逐元素加法操作
DataFrame.sub(other, axis, level, fill_value) 用于执行逐元素的减法操作
DataFrame.mul(other, axis, level, fill_value) 用于执行逐元素的乘法操作
DataFrame.div(other, axis, level, fill_value) 用于执行逐元素的除法操作
DataFrame.truediv(other, axis, level, ...) 用于执行逐元素的真除法操作
DataFrame.floordiv(other, axis, level, ...) 用于执行逐元素的地板除法操作
DataFrame.mod(other, axis, level, fill_value) 用于执行逐元素的取模操作
DataFrame.pow(other, axis, level, fill_value) 用于对 DataFrame 中的元素进行幂运算
DataFrame.dot(other) 用于计算两个 DataFrame(或 DataFrame 与 Series/数组)之间的**矩阵点积(矩阵乘法)**的方法
DataFrame.radd(other, axis, level, fill_value) 用于执行反向加法运算
DataFrame.rsub(other, axis, level, fill_value) 用于执行反向减法运算

pandas.DataFrame.rsub()

pandas.DataFrame.rsub 方法用于执行反向减法运算。具体来说,它相当于调用 other - self,其中 self 是调用该方法的 DataFrame。以下是该方法的参数说明及其功能:

参数说明
  • other: 用于进行减法运算的值,可以是标量、序列、DataFrame 或字典。
  • axis : 指定沿哪个轴进行运算。0'index' 表示沿行进行运算,1'columns' 表示沿列进行运算。默认为 1
  • level : 如果 other 是一个 MultiIndex,则指定沿哪个级别进行运算。默认为 None
  • fill_value : 用于填充缺失值的值。默认为 None
示例及结果
示例 1: 使用标量进行反向减法运算
python 复制代码
import pandas as pd

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

print("原始 DataFrame:")
print(df)

result = df.rsub(10)
print("\n反向减法后的 DataFrame (使用 rsub 并指定标量 10):")
print(result)

结果:

复制代码
原始 DataFrame:
   A  B  C
0  1  4  7
1  2  5  8
2  3  6  9

反向减法后的 DataFrame (使用 rsub 并指定标量 10):
    A   B   C
0   9   6   3
1   8   5   2
2   7   4   1
示例 2: 使用序列进行反向减法运算
python 复制代码
import pandas as pd

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

other = pd.Series([1, 2, 3])

print("原始 DataFrame:")
print(df)

result = df.rsub(other, axis=0)
print("\n反向减法后的 DataFrame (使用 rsub 并指定序列):")
print(result)

结果:

复制代码
原始 DataFrame:
   A  B  C
0  1  4  7
1  2  5  8
2  3  6  9

反向减法后的 DataFrame (使用 rsub 并指定序列):
    A   B   C
0   0  -3  -6
1   0  -3  -6
2   0  -3  -6
示例 3: 使用 DataFrame 进行反向减法运算
python 复制代码
import pandas as pd

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

other_df = pd.DataFrame({
    'A': [1, 2, 3],
    'B': [4, 5, 6],
    'C': [7, 8, 9]
})

print("原始 DataFrame:")
print(df)

result = df.rsub(other_df)
print("\n反向减法后的 DataFrame (使用 rsub 并指定 DataFrame):")
print(result)

结果:

复制代码
原始 DataFrame:
   A  B  C
0  1  4  7
1  2  5  8
2  3  6  9

反向减法后的 DataFrame (使用 rsub 并指定 DataFrame):
   A  B  C
0  0  0  0
1  0  0  0
2  0  0  0
示例 4: 使用字典进行反向减法运算
python 复制代码
import pandas as pd

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

other_dict = {'A': 1, 'B': 2, 'C': 3}

print("原始 DataFrame:")
print(df)

result = df.rsub(other_dict)
print("\n反向减法后的 DataFrame (使用 rsub 并指定字典):")
print(result)

结果:

复制代码
原始 DataFrame:
   A  B  C
0  1  4  7
1  2  5  8
2  3  6  9

反向减法后的 DataFrame (使用 rsub 并指定字典):
   A  B  C
0  0 -2 -4
1  0 -3 -5
2  0 -4 -6
解释
  1. 使用标量进行反向减法运算:

    • df.rsub(10) 计算 DataFrame df 中的每个元素与标量 10 的减法。
    • 结果是一个新的 DataFrame,其中每个元素是 10 减去 df 中的元素。
  2. 使用序列进行反向减法运算:

    • df.rsub(other, axis=0) 计算 DataFrame df 的每一行与序列 other 的对应元素的减法。
    • 结果是一个新的 DataFrame,其中每个元素是 other 的对应元素减去 df 的元素。
  3. 使用 DataFrame 进行反向减法运算:

    • df.rsub(other_df) 计算 DataFrame dfother_df 的对应元素的减法。
    • 结果是一个新的 DataFrame,其中每个元素是 other_df 的元素减去 df 的元素。
  4. 使用字典进行反向减法运算:

    • df.rsub(other_dict) 计算 DataFrame df 的每一列与字典 other_dict 中对应键的值的减法。
    • 结果是一个新的 DataFrame,其中每个元素是字典 other_dict 中的值减去 df 的元素。

这些示例展示了 DataFrame.rsub 方法的不同用法及其效果。根据具体需求,可以选择合适的参数来进行反向减法运算。

相关推荐
金銀銅鐵7 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li9 小时前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸13 小时前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学14 小时前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田1 天前
Pydantic校验配置文件
python
hboot1 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽2 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187912 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python