python - pandas 数据框中的 If/Else 流控制

标签 python python-3.x pandas if-statement dataframe

我是Python新手,正在研究逻辑语句。 我的目标是统计各队的进球得分。 (即如果一支球队进球,我将分配 1,而对手将分配 -1)。下面是数据快照。 Data is below

我写的逻辑语句如下:

if data['team']== data['hometeam_team1']:
   data['run_score'] = 1
else:
    data['run_score'] = -1

但它给我带来了值(value)错误:

ValueError: The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all().

有人可以建议吗? 非常感谢您的帮助。 谢谢 昂

最佳答案

使用panda的好处是矢量化计算。换句话说,您很少需要使用显式的 for 循环或 if/else 子句来执行计算在每一行。

相反,您可以对 pd.Series 对象执行计算。在此示例中,一种有效的解决方案是使用 numpy.where它的作用类似于矢量化的 if/else 子句:

import numpy as np

data['run_score'] = np.where(data['team']== data['hometeam_team1'], 1, -1)

关于python - pandas 数据框中的 If/Else 流控制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50191215/

相关文章:

python - 使用pandas包在python中合并多个excel文件的数据

python - 从字典中打印单个唯一行而不重复

python - 如何在Kivy中使用TreeView?

python - 如何在运行 Django 测试之前加载测试 yaml 文件?

python - 是什么导致了这个程序的错误

python-3.x - 客户端凭据流中的 requests-oauthlib 自动刷新不记名 token ?

python - 如何将多个字典中的数据合并到 DataFrame 中的一行中

python - python pandas 稀疏数据帧是否丢失多索引列名称或者我做错了?

python - Append 函数无法退出 for 循环

Python PIL 图像保存