作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
尝试根据 GF 和 GA 创建一个新列“Results”。想知道如何通过定义函数和条件语句来做到这一点。以下是我对一行的初步尝试,但无法弄清楚如何将其应用于所有行,非常感谢您的帮助!
原始输入:
df = pd.DataFrame({'Date': ['08-19-2017', '08-27-2017', '09-16-2017', '10-14-2017', '10-28-2017'],
'Venue': ['H', 'H', 'H', 'H', 'H'],
'Opponent': ['Crystal Palace', 'Arsenal FC', 'Burnley FC', 'Manchester United', 'Huddersfield Town'],
'GF': [1, 4, 1, 0, 3],
'GA': [0, 0, 1, 0, 0]})
我的尝试:
# for one row (match)
gf = df[0, 3]
ga = df[0, 4]
if gf > ga:
print('W')
elif gf < ga:
print('L')
else:
print('D')
输出:W
要将其应用于所有行,我将如何根据以下内容制定解决方案:
```# create a function
def win_draw_loss():
if df['GF'] > df['GA']:
print('W')
elif mo_rec['GF'].sum() < mo_rec['GA'].sum():
print('L')
else:
print('D')
# making the new pandas column
df['results'] = ```
最佳答案
您可以稍微更正您的 win_draw_loss
函数并将其应用于 DataFrame df
的每一行。下面更正了您的函数的问题是,如果您想将 win_draw_loss
应用于 DataFrame,则它必须将行数据作为参数,因此您的评估也需要针对行数据。
def win_draw_loss(x):
if x['GF'] > x['GA']:
return 'W'
elif x['GF'] < x['GA']:
return 'L'
else:
return 'D'
df['Results'] = df.apply(win_draw_loss, axis=1)
你也可以使用np.select
:
import numpy as np
df['Results'] = np.select([df['GF'] > df['GA'], df['GF'] < df['GA']], ['W', 'L'], 'D')
输出:
Date Venue Opponent GF GA Results
0 08-19-2017 H Crystal Palace 1 0 W
1 08-27-2017 H Arsenal FC 4 0 W
2 09-16-2017 H Burnley FC 1 1 D
3 10-14-2017 H Manchester United 0 0 D
4 10-28-2017 H Huddersfield Town 3 0 W
关于python - 目标和目标我想返回结果(赢、平、输)。 Pandas python ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70600445/
使用登录后,我想吐出用户名。 但是,当我尝试单击登录按钮时, 它给了我力量。 我看着logcat,但是什么也没显示。 这种编码是在说。 它将根据我在登录屏幕中输入的名称来烘烤用户名。 不会有任何密码。
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎是题外话,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或include a min
我是一名优秀的程序员,十分优秀!