{ "cells": [ { "cell_type": "markdown", "id": "1ee69dc3-2f18-4110-a232-81d807884da9", "metadata": {}, "source": [ "# FBRef" ] }, { "cell_type": "code", "execution_count": 1, "id": "2077b457-872d-420d-8799-9457e1a8f50f", "metadata": { "tags": [] }, "outputs": [], "source": [ "import sys\n", "\n", "sys.path.append(\"../../\")\n", "\n", "import penaltyblog as pb" ] }, { "cell_type": "markdown", "id": "56a9acc8-bf3a-4b1d-becb-f9b1e9ca1a09", "metadata": {}, "source": [ "## List available competitions" ] }, { "cell_type": "code", "execution_count": 2, "id": "bea88bf4-476f-4445-9345-379795d85025", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/plain": [ "['BEL First Division A',\n", " 'BEL First Division B',\n", " 'DEU Bundesliga 1',\n", " 'DEU Bundesliga 2',\n", " 'ENG Premier League',\n", " 'ENG Championship',\n", " 'ENG League 1',\n", " 'ENG League 2',\n", " 'ENG Conference',\n", " 'ESP La Liga',\n", " 'ESP La Liga Segunda',\n", " 'FRA Ligue 1',\n", " 'FRA Ligue 2',\n", " 'GRC Super League',\n", " 'ITA Serie A',\n", " 'ITA Serie B',\n", " 'NLD Eredivisie',\n", " 'PRT Liga 1',\n", " 'RUS Premier League',\n", " 'SCO Premier League',\n", " 'SCO Division 1',\n", " 'TUR Super Lig']" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "pb.scrapers.FBRef.list_competitions()" ] }, { "cell_type": "markdown", "id": "c22b88a5-d0bc-4553-a1b6-700c630a36a7", "metadata": {}, "source": [ "## Get fixtures" ] }, { "cell_type": "code", "execution_count": 3, "id": "88b75ca5-90dd-4a6e-a0b4-4b1a5a63fec2", "metadata": { "tags": [] }, "outputs": [ { "name": "stderr", "output_type": "stream", "text": [ "/Users/martin/repos/penaltyblog/examples/scrapers/../../penaltyblog/scrapers/fbref.py:160: FutureWarning: Passing literal html to 'read_html' is deprecated and will be removed in a future version. To read from a literal string, wrap it in a 'StringIO' object.\n", " pd.read_html(content)[0]\n" ] }, { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
competitionseasondatetimeweekdaydatetimeteam_homexg_homexg_awayteam_awayattendancevenuerefereegoals_homegoals_away
id
1659657600---crystal_palace---arsenalENG Premier League2022-20232022-08-05 20:00:001.0Fri2022-08-0520:00Crystal Palace1.21.0Arsenal25286.0Selhurst ParkAnthony Taylor0.02.0
1659744000---bournemouth---aston_villaENG Premier League2022-20232022-08-06 15:00:001.0Sat2022-08-0615:00Bournemouth0.60.7Aston Villa11013.0Vitality StadiumPeter Bankes2.00.0
1659744000---everton---chelseaENG Premier League2022-20232022-08-06 17:30:001.0Sat2022-08-0617:30Everton0.71.5Chelsea39254.0Goodison ParkCraig Pawson0.01.0
1659744000---fulham---liverpoolENG Premier League2022-20232022-08-06 12:30:001.0Sat2022-08-0612:30Fulham1.21.2Liverpool22207.0Craven CottageAndy Madley2.02.0
1659744000---leeds_united---wolvesENG Premier League2022-20232022-08-06 15:00:001.0Sat2022-08-0615:00Leeds United0.81.3Wolves36347.0Elland RoadRobert Jones2.01.0
\n", "
" ], "text/plain": [ " competition season \\\n", "id \n", "1659657600---crystal_palace---arsenal ENG Premier League 2022-2023 \n", "1659744000---bournemouth---aston_villa ENG Premier League 2022-2023 \n", "1659744000---everton---chelsea ENG Premier League 2022-2023 \n", "1659744000---fulham---liverpool ENG Premier League 2022-2023 \n", "1659744000---leeds_united---wolves ENG Premier League 2022-2023 \n", "\n", " datetime week day \\\n", "id \n", "1659657600---crystal_palace---arsenal 2022-08-05 20:00:00 1.0 Fri \n", "1659744000---bournemouth---aston_villa 2022-08-06 15:00:00 1.0 Sat \n", "1659744000---everton---chelsea 2022-08-06 17:30:00 1.0 Sat \n", "1659744000---fulham---liverpool 2022-08-06 12:30:00 1.0 Sat \n", "1659744000---leeds_united---wolves 2022-08-06 15:00:00 1.0 Sat \n", "\n", " date time team_home \\\n", "id \n", "1659657600---crystal_palace---arsenal 2022-08-05 20:00 Crystal Palace \n", "1659744000---bournemouth---aston_villa 2022-08-06 15:00 Bournemouth \n", "1659744000---everton---chelsea 2022-08-06 17:30 Everton \n", "1659744000---fulham---liverpool 2022-08-06 12:30 Fulham \n", "1659744000---leeds_united---wolves 2022-08-06 15:00 Leeds United \n", "\n", " xg_home xg_away team_away \\\n", "id \n", "1659657600---crystal_palace---arsenal 1.2 1.0 Arsenal \n", "1659744000---bournemouth---aston_villa 0.6 0.7 Aston Villa \n", "1659744000---everton---chelsea 0.7 1.5 Chelsea \n", "1659744000---fulham---liverpool 1.2 1.2 Liverpool \n", "1659744000---leeds_united---wolves 0.8 1.3 Wolves \n", "\n", " attendance venue \\\n", "id \n", "1659657600---crystal_palace---arsenal 25286.0 Selhurst Park \n", "1659744000---bournemouth---aston_villa 11013.0 Vitality Stadium \n", "1659744000---everton---chelsea 39254.0 Goodison Park \n", "1659744000---fulham---liverpool 22207.0 Craven Cottage \n", "1659744000---leeds_united---wolves 36347.0 Elland Road \n", "\n", " referee goals_home goals_away \n", "id \n", "1659657600---crystal_palace---arsenal Anthony Taylor 0.0 2.0 \n", "1659744000---bournemouth---aston_villa Peter Bankes 2.0 0.0 \n", "1659744000---everton---chelsea Craig Pawson 0.0 1.0 \n", "1659744000---fulham---liverpool Andy Madley 2.0 2.0 \n", "1659744000---leeds_united---wolves Robert Jones 2.0 1.0 " ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "fbref = pb.scrapers.FBRef(\"ENG Premier League\", \"2022-2023\")\n", "df = fbref.get_fixtures()\n", "df.head()" ] }, { "cell_type": "markdown", "id": "5efb2de7-dee1-477d-89a3-35e4979cd608", "metadata": {}, "source": [ "## List stats available for this competition" ] }, { "cell_type": "code", "execution_count": 4, "id": "5c7bef65-a41b-424e-97bc-1e822688a450", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/plain": [ "['standard',\n", " 'goalkeeping',\n", " 'advanced_goalkeeping',\n", " 'shooting',\n", " 'passing',\n", " 'passing_types',\n", " 'goal_shot_creation',\n", " 'defensive_actions',\n", " 'possession',\n", " 'playing_time',\n", " 'misc']" ] }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "fbref.list_stat_types()" ] }, { "cell_type": "markdown", "id": "99cf8346-4d24-46f2-9217-7425e96dee69", "metadata": {}, "source": [ "## Get stats" ] }, { "cell_type": "code", "execution_count": 5, "id": "47cc9ddc-f3a8-4dff-a1c2-d84524cb30fe", "metadata": { "tags": [] }, "outputs": [ { "name": "stderr", "output_type": "stream", "text": [ "/Users/martin/repos/penaltyblog/examples/scrapers/../../penaltyblog/scrapers/fbref.py:233: FutureWarning: Passing literal html to 'read_html' is deprecated and will be removed in a future version. To read from a literal string, wrap it in a 'StringIO' object.\n", " dfs = pd.read_html(content)\n" ] } ], "source": [ "stats = fbref.get_stats(\"standard\")" ] }, { "cell_type": "code", "execution_count": 6, "id": "34c8172f-b721-4f44-ad00-962a1c81adb0", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
nationpossquadbornplaying_time_mpplaying_time_startsplaying_time_minplaying_time_90sperformance_glsperformance_ast...per_90_minutes_g-pkper_90_minutes_g+a-pkper_90_minutes_xgper_90_minutes_xagper_90_minutes_xg+xagper_90_minutes_npxgper_90_minutes_npxg+xagseasoncompetitionage_years
player
Aaron Cresswelleng ENGDFWest Ham198928.024.02235.024.801...0.000.040.010.150.160.010.162022-2023ENG Premier League32.0
Aaron Hickeysct SCODFBrentford200226.023.01916.021.301...0.000.050.020.020.040.020.042022-2023ENG Premier League20.0
Aaron Ramsdaleeng ENGGKArsenal199838.038.03420.038.000...0.000.000.000.000.000.000.002022-2023ENG Premier League24.0
Aaron Wan-Bissakaeng ENGDFManchester Utd199719.016.01435.015.900...0.000.000.070.060.140.070.142022-2023ENG Premier League24.0
Abdoulaye Doucouréml MLIMFEverton199325.017.01533.017.052...0.290.410.140.130.270.140.272022-2023ENG Premier League29.0
\n", "

5 rows × 36 columns

\n", "
" ], "text/plain": [ " nation pos squad born playing_time_mp \\\n", "player \n", "Aaron Cresswell eng ENG DF West Ham 1989 28.0 \n", "Aaron Hickey sct SCO DF Brentford 2002 26.0 \n", "Aaron Ramsdale eng ENG GK Arsenal 1998 38.0 \n", "Aaron Wan-Bissaka eng ENG DF Manchester Utd 1997 19.0 \n", "Abdoulaye Doucouré ml MLI MF Everton 1993 25.0 \n", "\n", " playing_time_starts playing_time_min playing_time_90s \\\n", "player \n", "Aaron Cresswell 24.0 2235.0 24.8 \n", "Aaron Hickey 23.0 1916.0 21.3 \n", "Aaron Ramsdale 38.0 3420.0 38.0 \n", "Aaron Wan-Bissaka 16.0 1435.0 15.9 \n", "Abdoulaye Doucouré 17.0 1533.0 17.0 \n", "\n", " performance_gls performance_ast ... per_90_minutes_g-pk \\\n", "player ... \n", "Aaron Cresswell 0 1 ... 0.00 \n", "Aaron Hickey 0 1 ... 0.00 \n", "Aaron Ramsdale 0 0 ... 0.00 \n", "Aaron Wan-Bissaka 0 0 ... 0.00 \n", "Abdoulaye Doucouré 5 2 ... 0.29 \n", "\n", " per_90_minutes_g+a-pk per_90_minutes_xg per_90_minutes_xag \\\n", "player \n", "Aaron Cresswell 0.04 0.01 0.15 \n", "Aaron Hickey 0.05 0.02 0.02 \n", "Aaron Ramsdale 0.00 0.00 0.00 \n", "Aaron Wan-Bissaka 0.00 0.07 0.06 \n", "Abdoulaye Doucouré 0.41 0.14 0.13 \n", "\n", " per_90_minutes_xg+xag per_90_minutes_npxg \\\n", "player \n", "Aaron Cresswell 0.16 0.01 \n", "Aaron Hickey 0.04 0.02 \n", "Aaron Ramsdale 0.00 0.00 \n", "Aaron Wan-Bissaka 0.14 0.07 \n", "Abdoulaye Doucouré 0.27 0.14 \n", "\n", " per_90_minutes_npxg+xag season competition \\\n", "player \n", "Aaron Cresswell 0.16 2022-2023 ENG Premier League \n", "Aaron Hickey 0.04 2022-2023 ENG Premier League \n", "Aaron Ramsdale 0.00 2022-2023 ENG Premier League \n", "Aaron Wan-Bissaka 0.14 2022-2023 ENG Premier League \n", "Abdoulaye Doucouré 0.27 2022-2023 ENG Premier League \n", "\n", " age_years \n", "player \n", "Aaron Cresswell 32.0 \n", "Aaron Hickey 20.0 \n", "Aaron Ramsdale 24.0 \n", "Aaron Wan-Bissaka 24.0 \n", "Abdoulaye Doucouré 29.0 \n", "\n", "[5 rows x 36 columns]" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "stats[\"players\"].head()" ] }, { "cell_type": "code", "execution_count": 7, "id": "5b2e972b-5ed1-4ff6-b501-e140c02dbe82", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
#_plagepossplaying_time_mpplaying_time_startsplaying_time_minplaying_time_90sperformance_glsperformance_astperformance_g+a...per_90_minutes_g+aper_90_minutes_g-pkper_90_minutes_g+a-pkper_90_minutes_xgper_90_minutes_xagper_90_minutes_xg+xagper_90_minutes_npxgper_90_minutes_npxg+xagseasoncompetition
squad
Arsenal2624.759.338.0418.03420.038.08464148...3.892.133.821.881.413.291.813.222022-2023ENG Premier League
Aston Villa2627.049.338.0418.03420.038.0493584...2.211.212.131.321.022.341.242.262022-2023ENG Premier League
Bournemouth3126.340.438.0418.03420.038.0372461...1.610.971.611.010.751.761.011.762022-2023ENG Premier League
Brentford2526.243.838.0418.03420.038.0563692...2.421.292.241.481.012.491.322.332022-2023ENG Premier League
Brighton2926.360.238.0418.03420.038.06846114...3.001.632.841.931.373.301.813.192022-2023ENG Premier League
\n", "

5 rows × 33 columns

\n", "
" ], "text/plain": [ " #_pl age poss playing_time_mp playing_time_starts \\\n", "squad \n", "Arsenal 26 24.7 59.3 38.0 418.0 \n", "Aston Villa 26 27.0 49.3 38.0 418.0 \n", "Bournemouth 31 26.3 40.4 38.0 418.0 \n", "Brentford 25 26.2 43.8 38.0 418.0 \n", "Brighton 29 26.3 60.2 38.0 418.0 \n", "\n", " playing_time_min playing_time_90s performance_gls \\\n", "squad \n", "Arsenal 3420.0 38.0 84 \n", "Aston Villa 3420.0 38.0 49 \n", "Bournemouth 3420.0 38.0 37 \n", "Brentford 3420.0 38.0 56 \n", "Brighton 3420.0 38.0 68 \n", "\n", " performance_ast performance_g+a ... per_90_minutes_g+a \\\n", "squad ... \n", "Arsenal 64 148 ... 3.89 \n", "Aston Villa 35 84 ... 2.21 \n", "Bournemouth 24 61 ... 1.61 \n", "Brentford 36 92 ... 2.42 \n", "Brighton 46 114 ... 3.00 \n", "\n", " per_90_minutes_g-pk per_90_minutes_g+a-pk per_90_minutes_xg \\\n", "squad \n", "Arsenal 2.13 3.82 1.88 \n", "Aston Villa 1.21 2.13 1.32 \n", "Bournemouth 0.97 1.61 1.01 \n", "Brentford 1.29 2.24 1.48 \n", "Brighton 1.63 2.84 1.93 \n", "\n", " per_90_minutes_xag per_90_minutes_xg+xag per_90_minutes_npxg \\\n", "squad \n", "Arsenal 1.41 3.29 1.81 \n", "Aston Villa 1.02 2.34 1.24 \n", "Bournemouth 0.75 1.76 1.01 \n", "Brentford 1.01 2.49 1.32 \n", "Brighton 1.37 3.30 1.81 \n", "\n", " per_90_minutes_npxg+xag season competition \n", "squad \n", "Arsenal 3.22 2022-2023 ENG Premier League \n", "Aston Villa 2.26 2022-2023 ENG Premier League \n", "Bournemouth 1.76 2022-2023 ENG Premier League \n", "Brentford 2.33 2022-2023 ENG Premier League \n", "Brighton 3.19 2022-2023 ENG Premier League \n", "\n", "[5 rows x 33 columns]" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "stats[\"squad_for\"].head()" ] }, { "cell_type": "code", "execution_count": 8, "id": "5e0d3dbd-eb49-4349-ad80-d07e32c32537", "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
#_plagepossplaying_time_mpplaying_time_startsplaying_time_minplaying_time_90sperformance_glsperformance_astperformance_g+a...per_90_minutes_g+aper_90_minutes_g-pkper_90_minutes_g+a-pkper_90_minutes_xgper_90_minutes_xagper_90_minutes_xg+xagper_90_minutes_npxgper_90_minutes_npxg+xagseasoncompetition
squad
vs Arsenal2626.740.138.0418.03420.038.0422769...1.821.031.741.100.831.931.001.832022-2023ENG Premier League
vs Aston Villa2626.550.638.0418.03420.038.0422567...1.760.971.631.380.952.331.262.212022-2023ENG Premier League
vs Bournemouth3126.659.938.0418.03420.038.06849117...3.081.632.921.681.192.871.542.732022-2023ENG Premier League
vs Brentford2526.656.638.0418.03420.038.0433073...1.921.081.871.280.942.221.252.192022-2023ENG Premier League
vs Brighton2926.539.538.0418.03420.038.0473481...2.131.081.971.320.892.211.152.042022-2023ENG Premier League
\n", "

5 rows × 33 columns

\n", "
" ], "text/plain": [ " #_pl age poss playing_time_mp playing_time_starts \\\n", "squad \n", "vs Arsenal 26 26.7 40.1 38.0 418.0 \n", "vs Aston Villa 26 26.5 50.6 38.0 418.0 \n", "vs Bournemouth 31 26.6 59.9 38.0 418.0 \n", "vs Brentford 25 26.6 56.6 38.0 418.0 \n", "vs Brighton 29 26.5 39.5 38.0 418.0 \n", "\n", " playing_time_min playing_time_90s performance_gls \\\n", "squad \n", "vs Arsenal 3420.0 38.0 42 \n", "vs Aston Villa 3420.0 38.0 42 \n", "vs Bournemouth 3420.0 38.0 68 \n", "vs Brentford 3420.0 38.0 43 \n", "vs Brighton 3420.0 38.0 47 \n", "\n", " performance_ast performance_g+a ... per_90_minutes_g+a \\\n", "squad ... \n", "vs Arsenal 27 69 ... 1.82 \n", "vs Aston Villa 25 67 ... 1.76 \n", "vs Bournemouth 49 117 ... 3.08 \n", "vs Brentford 30 73 ... 1.92 \n", "vs Brighton 34 81 ... 2.13 \n", "\n", " per_90_minutes_g-pk per_90_minutes_g+a-pk per_90_minutes_xg \\\n", "squad \n", "vs Arsenal 1.03 1.74 1.10 \n", "vs Aston Villa 0.97 1.63 1.38 \n", "vs Bournemouth 1.63 2.92 1.68 \n", "vs Brentford 1.08 1.87 1.28 \n", "vs Brighton 1.08 1.97 1.32 \n", "\n", " per_90_minutes_xag per_90_minutes_xg+xag \\\n", "squad \n", "vs Arsenal 0.83 1.93 \n", "vs Aston Villa 0.95 2.33 \n", "vs Bournemouth 1.19 2.87 \n", "vs Brentford 0.94 2.22 \n", "vs Brighton 0.89 2.21 \n", "\n", " per_90_minutes_npxg per_90_minutes_npxg+xag season \\\n", "squad \n", "vs Arsenal 1.00 1.83 2022-2023 \n", "vs Aston Villa 1.26 2.21 2022-2023 \n", "vs Bournemouth 1.54 2.73 2022-2023 \n", "vs Brentford 1.25 2.19 2022-2023 \n", "vs Brighton 1.15 2.04 2022-2023 \n", "\n", " competition \n", "squad \n", "vs Arsenal ENG Premier League \n", "vs Aston Villa ENG Premier League \n", "vs Bournemouth ENG Premier League \n", "vs Brentford ENG Premier League \n", "vs Brighton ENG Premier League \n", "\n", "[5 rows x 33 columns]" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "stats[\"squad_against\"].head()" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.13.0" }, "vscode": { "interpreter": { "hash": "5c7b89af1651d0b8571dde13640ecdccf7d5a6204171d6ab33e7c296e100e08a" } } }, "nbformat": 4, "nbformat_minor": 5 }