#python #dataframe
Вопрос:
Я пытаюсь создать карту снимков, соскабливая данные с веб-сайта, чтобы найти данные о футболе. Я хочу, чтобы кадры hometeam были на одной стороне поля, а кадры awayteam-на другой стороне. Какая-нибудь помощь? Я пытаюсь решить проблему с помощью if-оператора с if h/a = h…. и еще….
import pandas as pd
import matplotlib as mpl
import matplotlib.pyplot as plt
from mplsoccer.pitch import Pitch
from pandas.core.indexes.base import Index
text_color = 'w'
data = pd.read_csv('shotmaps.csv')
fig, ax = plt.subplots(figsize=(13,8.5))
fig.set_facecolor('#22312b')
ax.patch.set_facecolor('#22312b')
pitch = Pitch(half=False, positional=True, shade_middle=True, positional_color='black', line_color='black', axis=True, label=True, tick=True)
pitch.draw(ax=ax)
plt.title('Manchester United vs Newcastle', fontsize=24, c=text_color)
if data['H/A'].eq('h').any():
plt.scatter(data['x-coordinate']*120,data['y-coordinate']*80, c = '#ea6969', s=70)
if data['H/A'].eq('a').any():
plt.gca().invert_xaxis()
plt.scatter(data['x-coordinate']*120,data['y-coordinate']*80, c = 'blue', s=70)
Это csv, из которого я получаю свой фрейм данных:
Unnamed: 0 Minute Player Situation Team
0 0 8 Cristiano Ronaldo OpenPlay Manchester United
1 1 10 Cristiano Ronaldo OpenPlay Manchester United
2 2 18 Raphael Varane FromCorner Manchester United
3 3 22 Cristiano Ronaldo OpenPlay Manchester United
4 4 25 Bruno Fernandes OpenPlay Manchester United
5 5 28 Bruno Fernandes OpenPlay Manchester United
6 6 29 Bruno Fernandes OpenPlay Manchester United
7 7 29 Jadon Sancho OpenPlay Manchester United
8 8 31 Jadon Sancho OpenPlay Manchester United
9 9 31 Harry Maguire FromCorner Manchester United
10 10 38 Cristiano Ronaldo OpenPlay Manchester United
11 11 42 Nemanja Matic OpenPlay Manchester United
12 12 46 Mason Greenwood OpenPlay Manchester United
13 13 46 Cristiano Ronaldo OpenPlay Manchester United
14 14 53 Nemanja Matic OpenPlay Manchester United
15 15 58 Bruno Fernandes OpenPlay Manchester United
16 16 61 Cristiano Ronaldo OpenPlay Manchester United
17 17 65 Raphael Varane FromCorner Manchester United
18 18 75 Mason Greenwood FromCorner Manchester United
19 19 79 Bruno Fernandes OpenPlay Manchester United
20 20 91 Jesse Lingard OpenPlay Manchester United
21 21 6 Joelinton OpenPlay Newcastle United
22 22 14 Matt Ritchie OpenPlay Newcastle United
23 23 22 Miguel Almirón OpenPlay Newcastle United
24 24 22 Matt Ritchie OpenPlay Newcastle United
25 25 27 Joe Willock OpenPlay Newcastle United
26 26 35 Allan Saint-Maximin SetPiece Newcastle United
27 27 55 Javier Manquillo OpenPlay Newcastle United
28 28 66 Joelinton OpenPlay Newcastle United
29 29 68 Allan Saint-Maximin OpenPlay Newcastle United
30 30 78 Allan Saint-Maximin OpenPlay Newcastle United
31 31 79 Joe Willock FromCorner Newcastle United
32 32 86 Joelinton OpenPlay Newcastle United
xG Result x-coordinate y-coordinate H/A
0 0.057108 MissedShots 0.978 0.338 h
1 0.039677 MissedShots 0.972 0.720 h
2 0.219654 MissedShots 0.930 0.616 h
3 0.026905 BlockedShot 0.766 0.521 h
4 0.006393 MissedShots 0.494 0.800 h
5 0.009298 MissedShots 0.718 0.804 h
6 0.021526 MissedShots 0.744 0.452 h
7 0.369672 MissedShots 0.892 0.514 h
8 0.128696 BlockedShot 0.851 0.527 h
9 0.042829 SavedShot 0.905 0.424 h
10 0.108275 BlockedShot 0.940 0.342 h
11 0.014675 BlockedShot 0.732 0.382 h
12 0.015693 SavedShot 0.802 0.176 h
13 0.887859 Goal 0.976 0.516 h
14 0.015525 MissedShots 0.697 0.488 h
15 0.030891 BlockedShot 0.787 0.418 h
16 0.301787 Goal 0.923 0.632 h
17 0.070338 MissedShots 0.905 0.519 h
18 0.027712 BlockedShot 0.862 0.285 h
19 0.031612 Goal 0.756 0.499 h
20 0.369022 Goal 0.865 0.522 h
21 0.070895 MissedShots 0.860 0.675 a
22 0.016308 BlockedShot 0.767 0.720 a
23 0.011347 BlockedShot 0.744 0.310 a
24 0.014497 MissedShots 0.784 0.699 a
25 0.068061 MissedShots 0.927 0.330 a
26 0.015108 MissedShots 0.765 0.707 a
27 0.264944 Goal 0.933 0.328 a
28 0.060307 SavedShot 0.872 0.660 a
29 0.006815 MissedShots 0.698 0.726 a
30 0.020886 BlockedShot 0.739 0.479 a
31 0.013166 SavedShot 0.706 0.464 a
32 0.059875 MissedShots 0.912 0.593 a
Комментарии:
1. Пожалуйста, исправьте отступ в коде.
2. Что ты имеешь в виду? Я новичок в StackOverflow и кодировании в целом
3. Все строки от
import pandas as pd
доpitch.draw(ax=ax)
должны быть на левом поле, без отступов. Правильный отступ имеет решающее значение в Python.4. Это была просто проблема с тем, что я ввел код здесь, он правильный в моем реальном коде
5. Я знаю это. Но если вам нужна помощь здесь, напишите правильный код.
Ответ №1:
Во-первых, разделите свой фрейм данных на домашнюю и выездную команды:
home_team = df.loc[df["H/A"] == "h"]
away_team = df.loc[df["H/A"] == "a"]
Теперь предположим, что команда хозяев атакует слева направо. Координата x, скажем, 0.9
указывает на то, что команда хозяев выстрелила с места, расположенного на 90% выше по полю от их цели, которая будет находиться в координате x 0.9 * pitch_length
.
С другой стороны, команда гостей, стреляющая в 0.9
цель, указывала бы место на 90% выше по полю от их цели или на 10% выше по полю от цели домашней команды. Другими словами, x = (1 - 0.9) * pitch_length
Так что сделай это.
plt.scatter(home_team['x-coordinate']*120, home_team['y-coordinate']*80, c = '#ea6969', s=70)
plt.scatter((1-away_team['x-coordinate'])*120, away_team['y-coordinate']*80, c = 'blue', s=70)