The goal of fitzRoy has been to provide a consistent and easy to use
interface for accessing data from various sources. As of version
0.3.3.9000 of fitzRoy
, the package now contains a much more
consistent API to do so. This is with the introduction of the main
fetch_*
functions.
Each function uses the same arguments and each argument should behave the same across all of the functions. While there may be some slight differences in behaviour between different sources of data, the goal will be to move towards a much more consistent pattern of behaviour.
There are a number of main functions
fetch_fixture
- returns the fixture for a given round
and seasonfetch_lineup
- returns the lineup any matches in a
given round and seasonfetch_results
- returns the match results for a given
round and seasonfetch_ladder
- returns the ladder for a given round and
seasonfetch_player_stats
- returns the detailed player stats
for a set of matches within a given round or seasonfetch_player_details
- returns details on players such
as date of birth, height, weight and debut (depending on source)Each function generally accepts 4 arguments. These are consistent between functions and provide sane and common defaults. The common arguments are:
season
- the season or seasons to return data from. If
NULL (the default), will return the season that matches
Sys.Date()
round_number
- the round to return data from. If NULL
(the default), will return data from all roundssource
- the source with which to return data from.
Must be one of “AFL” (default), “footywire”, “fryzigg”, “afltables”,
“squiggle”comp
- the competition to return data from. Must be one
of “AFLM” (default), “AFLW”, “VFL”, “VFLW”, “WAFL”, “U18B” or “U18G.”
Not all data sources will have non-AFL data.All of the functions behave the same. The following are some examples
using the fetch_fixture
function but can equally be applied
to any of the family of fetch_
functions.
fetch_fixture(2021)
#> # A tibble: 207 × 55
#> id providerId utcStartTime status compSeason.id compSeason.providerId
#> <int> <chr> <chr> <chr> <int> <chr>
#> 1 2991 CD_M20210140101 2021-03-18T… CONCL… 34 CD_S2021014
#> 2 2986 CD_M20210140102 2021-03-19T… CONCL… 34 CD_S2021014
#> 3 2992 CD_M20210140103 2021-03-20T… CONCL… 34 CD_S2021014
#> 4 2993 CD_M20210140104 2021-03-20T… CONCL… 34 CD_S2021014
#> 5 2994 CD_M20210140105 2021-03-20T… CONCL… 34 CD_S2021014
#> 6 2987 CD_M20210140106 2021-03-20T… CONCL… 34 CD_S2021014
#> 7 2990 CD_M20210140107 2021-03-21T… CONCL… 34 CD_S2021014
#> 8 2989 CD_M20210140108 2021-03-21T… CONCL… 34 CD_S2021014
#> 9 2988 CD_M20210140109 2021-03-21T… CONCL… 34 CD_S2021014
#> 10 2999 CD_M20210140201 2021-03-25T… CONCL… 34 CD_S2021014
#> # ℹ 197 more rows
#> # ℹ 49 more variables: compSeason.name <chr>, compSeason.shortName <chr>,
#> # compSeason.currentRoundNumber <int>, round.id <int>,
#> # round.providerId <chr>, round.abbreviation <chr>, round.name <chr>,
#> # round.roundNumber <int>, round.byes <list>, home.team.id <int>,
#> # home.team.providerId <chr>, home.team.name <chr>,
#> # home.team.abbreviation <chr>, home.team.nickname <chr>, …
This is the same as
fetch_fixture(season = 2021, comp = "AFLM", source = "AFL")
We can return just one round instead of the whole fixture.
fetch_fixture(season = 2021, round_number = 2) %>%
select(compSeason.name, round.name, home.team.name, away.team.name, venue.name)
#> # A tibble: 9 × 5
#> compSeason.name round.name home.team.name away.team.name venue.name
#> <chr> <chr> <chr> <chr> <chr>
#> 1 2021 Toyota AFL Premiersh… Round 2 Carlton Collingwood MCG
#> 2 2021 Toyota AFL Premiersh… Round 2 Geelong Cats Brisbane Lions GMHBA Sta…
#> 3 2021 Toyota AFL Premiersh… Round 2 Sydney Swans Adelaide Crows SCG
#> 4 2021 Toyota AFL Premiersh… Round 2 Port Adelaide Essendon Adelaide …
#> 5 2021 Toyota AFL Premiersh… Round 2 St Kilda Melbourne Marvel St…
#> 6 2021 Toyota AFL Premiersh… Round 2 Gold Coast Su… North Melbour… Metricon …
#> 7 2021 Toyota AFL Premiersh… Round 2 Hawthorn Richmond MCG
#> 8 2021 Toyota AFL Premiersh… Round 2 Western Bulld… West Coast Ea… Marvel St…
#> 9 2021 Toyota AFL Premiersh… Round 2 Fremantle GWS Giants Optus Sta…
We could also return the AFLW fixture instead.
fetch_fixture(season = 2021, comp = "AFLW") %>%
select(
compSeason.name, round.name,
home.team.name, away.team.name,
venue.name
)
#> # A tibble: 68 × 5
#> compSeason.name round.name home.team.name away.team.name venue.name
#> <chr> <chr> <chr> <chr> <chr>
#> 1 2021 NAB AFLW Competition Round 1 Carlton Collingwood Ikon Park
#> 2 2021 NAB AFLW Competition Round 1 St Kilda Western Bulld… RSEA Park
#> 3 2021 NAB AFLW Competition Round 1 Gold Coast Su… Melbourne Metricon …
#> 4 2021 NAB AFLW Competition Round 1 West Coast Ea… Adelaide Crows Mineral R…
#> 5 2021 NAB AFLW Competition Round 1 Geelong Cats Kangaroos GMHBA Sta…
#> 6 2021 NAB AFLW Competition Round 1 Richmond Brisbane Lions Swinburne…
#> 7 2021 NAB AFLW Competition Round 1 Fremantle GWS Giants Fremantle…
#> 8 2021 NAB AFLW Competition Round 2 Western Bulld… Carlton Victoria …
#> 9 2021 NAB AFLW Competition Round 2 Collingwood Geelong Cats Victoria …
#> 10 2021 NAB AFLW Competition Round 2 Melbourne Richmond Casey Fie…
#> # ℹ 58 more rows
Lastly - we can choose a different source. Note that the field names and even the names of the teams and/or venues will be different for difference sources.
fetch_fixture(2021, round_number = 1, source = "squiggle")
#> # A tibble: 207 × 24
#> is_grand_final date hscore ateamid agoals ascore hgoals hteamid localtime
#> <int> <chr> <int> <int> <int> <int> <int> <int> <chr>
#> 1 0 2021-03… 103 7 13 91 15 1 2021-03-…
#> 2 0 2021-03… 94 16 19 125 14 2 2021-03-…
#> 3 0 2021-03… 53 18 10 69 7 4 2021-03-…
#> 4 0 2021-03… 91 10 14 92 13 5 2021-03-…
#> 5 0 2021-03… 78 15 13 86 11 9 2021-03-…
#> 6 0 2021-03… 80 6 8 58 11 11 2021-03-…
#> 7 0 2021-03… 65 13 17 117 9 12 2021-03-…
#> 8 0 2021-03… 105 3 11 80 15 14 2021-03-…
#> 9 0 2021-03… 83 8 8 58 12 17 2021-03-…
#> 10 0 2021-03… 85 4 16 106 13 3 2021-03-…
#> # ℹ 197 more rows
#> # ℹ 15 more variables: abehinds <int>, tz <chr>, updated <chr>, ateam <chr>,
#> # complete <int>, winnerteamid <int>, year <int>, hbehinds <int>,
#> # venue <chr>, hteam <chr>, is_final <int>, id <int>, roundname <chr>,
#> # round <int>, winner <chr>
It should also be noted that the various sources of data have their own functions that can be called directly.
# The following are the same
fetch_fixture(2021, round_number = 5, source = "squiggle")
fetch_fixture_squiggle(2021, round_number = 5)
With these new functions we now have access to consistent AFLW data for the first time!
At a high level, any fetch_
function will allow you to
specify the that comp = "AFLW
and will return data. Please
note that Womens data only exists when source = "AFL"
,
which is the default for all fetch_
functions.
Read the full AFL Womens Vingette for specific examples.
An experimental feature as of version 1.2.0 is returning non-AFL
related data. This only works for the source AFL
but there
are other comps that are available. These comps do not have as much data
as the AFLM and AFLW comps but some functions will work.
fetch_fixture(2022, source = "AFL", comp = "VFL")
fetch_player_stats(2022, round = 1, source = "AFL", comp = "VFLW")
fetch_fixture(2022, source = "AFL", comp = "WAFL")
Available comps include * “VFL” * “VFLW” * “WAFL” * “U18B” * “U18G”