| Type: | Package | 
| Title: | Biodiversity Data from the GBIF Node Network | 
| Version: | 2.1.2 | 
| Description: | The Global Biodiversity Information Facility ('GBIF', https://www.gbif.org) sources data from an international network of data providers, known as 'nodes'. Several of these nodes - the "living atlases" (https://living-atlases.gbif.org) - maintain their own web services using software originally developed by the Atlas of Living Australia ('ALA', https://www.ala.org.au). 'galah' enables the R community to directly access data and resources hosted by 'GBIF' and its partner nodes. | 
| Depends: | R (≥ 4.3.0) | 
| Imports: | cli, crayon, dplyr, glue (≥ 1.3.2), httr2, jsonlite (≥ 0.9.8), lifecycle (≥ 1.0.0), potions (≥ 0.2.0), purrr, readr, rlang, sf, stringr, tibble, tidyr, tidyselect, utils, xml2 | 
| Suggests: | covr, gt, kableExtra, knitr, magrittr, pkgdown, reactable, rmarkdown, testthat | 
| License: | MPL-2.0 | 
| URL: | https://galah.ala.org.au/R/ | 
| BugReports: | https://github.com/AtlasOfLivingAustralia/galah-R/issues | 
| Maintainer: | Martin Westgate <martin.westgate@csiro.au> | 
| LazyLoad: | yes | 
| VignetteBuilder: | knitr | 
| RoxygenNote: | 7.3.2 | 
| Encoding: | UTF-8 | 
| NeedsCompilation: | no | 
| Packaged: | 2025-06-12 05:15:03 UTC; wes186 | 
| Author: | Martin Westgate [aut, cre], Dax Kellie [aut], Matilda Stevenson [aut], Peggy Newman [aut] | 
| Repository: | CRAN | 
| Date/Publication: | 2025-06-12 09:30:02 UTC | 
Biodiversity Data from the GBIF Node Network
Description
The Global Biodiversity Information Facility (GBIF; https://www.gbif.org)
provides tools to enable users to find, access, combine and visualise
biodiversity data. galah enables the R community to directly access data and
resources hosted by GBIF and several of it's subsidiary organisations, known
as 'nodes'.
The basic unit of data stored by these infrastructures is
an occurrence record, which is an observation of a biological entity at
a specific time and place. However, galah also facilitates access to
taxonomic information, or associated media such images or sounds,
all while restricting their queries to particular taxa or locations. Users
can specify which columns are returned by a query, or restrict their results
to observations that meet particular quality-control criteria.
For those outside Australia, 'galah' is the common name of Eolophus roseicapilla, a widely-distributed Australian bird species.
Functions
Getting Started
-  galah_call()/request_()Start to build a query
-  galah_config()Set package configuration options
-  show_all()&search_all()Data for generating filter queries
-  show_values()&search_values()Show or search for values withinfields,profiles,lists,collections,datasetsorproviders
Amend a query
-  apply_profile()/galah_apply_profile()Restrict to data that pass predefined checks (ALA only)
-  arrange()Arrange rows of a query on the server side
-  count()Request counts of the specified data type
-  desc()Arrange counts in descending order (when combined witharrange())
-  filter()/galah_filter()Filter records
-  geolocate()/galah_geolocate()Spatial filtering of a query
-  group_by()/galah_group_by()Group counts by one or more fields
-  identify()/galah_identify()Search for taxonomic identifiers (see alsotaxonomic_searches)
-  select()/galah_select()Fields to report information for
-  slice_head()Choose the first n rows of a download
-  unnest()Expand metadata forfields,lists,profilesortaxa
Execute a query via API
-  collapse()Convert adata_requestinto aquery
-  compute()Compute a query
-  collect()/atlas_()/collect_media()Retrieve a database query
Miscellaneous functions
-  atlas_citation()Get a citation for a dataset
-  read_zip()To read data from an earlier download
-  print()Print functions for galah objects
Terminology
To get the most value from galah, it is helpful to understand some
terminology. Each occurrence record contains taxonomic
information, and usually some information about the observation itself, such
as its location. In addition to this record-specific information, the living
atlases append contextual information to each record, particularly data from
spatial layers reflecting climate gradients or political boundaries. They
also run a number of quality checks against each record, resulting in
assertions attached to the record. Each piece of information
associated with a given occurrence record is stored in a field,
which corresponds to a column when imported to an
R data.frame. See show_all(fields) to view valid fields,
layers and assertions, or conduct a search using search_all(fields).
Data fields are important because they provide a means to filter
occurrence records;  i.e. to return only the information that you need, and
no more. Consequently, much of the architecture of galah has been
designed to make filtering as simple as possible. The easiest way to do this
is to start a pipe with galah_call() and follow it with the relevant
dplyr function; starting with filter(), but also including select(),
group_by() or others. Functions without a relevant dplyr synonym include
galah_identify()/identify() for choosing a taxon, or galah_geolocate()/
st_crop() for choosing a specific location. By combining different filters,
it is possible to build complex queries to return only the most valuable
information for a given problem.
A notable extension of the filtering approach is to remove records with low
'quality'. All living atlases perform quality control checks on all records
that they store. These checks are used to generate new fields, that can then
be used to filter out records that are unsuitable for particular applications.
However, there are many possible data quality checks, and it is not always
clear which are most appropriate in a given instance. Therefore, galah
supports data quality profiles, which can be passed to
galah_apply_profile() to quickly remove undesirable records. A full list of
data quality profiles is returned by show_all(profiles). Note this service
is currently only available for the Australian atlas (ALA).
Author(s)
Maintainer: Martin Westgate martin.westgate@csiro.au
Authors:
- Dax Kellie dax.kellie@csiro.au 
- Matilda Stevenson 
- Peggy Newman peggy.newman@csiro.au 
See Also
Useful links:
Apply a data quality profile
Description
A 'profile' is a group of filters that are pre-applied by the ALA. Using a data profile allows a query to be filtered quickly to the most relevant or quality-assured data that is fit-for-purpose. For example, the "ALA" profile is designed to exclude lower quality records, whereas other profiles apply filters specific to species distribution modelling (e.g. CDSM).
Note that only one profile can be loaded at a time; if multiple profiles are given, the first valid profile is used.
For more bespoke editing of filters within a profile, use
filter.data_request().
Usage
apply_profile(.data, ...)
galah_apply_profile(...)
Arguments
| .data | An object of class  | 
| ... | a profile name. Should be a  | 
Value
An updated data_request with a completed data_profile slot.
See Also
show_all() and search_all() to look up available data profiles.
filter.data_request() can be used for more bespoke editing of individual data
profile filters.
Examples
## Not run: 
# Apply a data quality profile to a query
galah_call() |> 
  identify("reptilia") |>
  filter(year == 2021) |>
  apply_profile(ALA) |>
  atlas_counts()
## End(Not run)
Order rows using column values
Description
arrange.data_request() arranges rows of a query on the server side, meaning
that the query is constructed in such a way that information will be arranged
when the query is processed. This only has an effect when used in combination
with count() and
group_by(). The benefit of using
arrange() within a galah_call() pipe is that it is sometimes beneficial
to choose a non-default order for data to be delivered in, particularly if
slice_head() is also called.
Usage
## S3 method for class 'data_request'
arrange(.data, ...)
## S3 method for class 'metadata_request'
arrange(.data, ...)
Arguments
| .data | An object of class  | 
| ... | A variable to arrange the resulting tibble by. Should be one of
the variables also listed in  | 
Value
An amended data_request with a completed arrange slot.
Examples
## Not run: 
# Arrange grouped counts by ascending year
galah_call() |>
  identify("Crinia") |>
  filter(year >= 2020) |>
  group_by(year) |>
  arrange(year) |>
  count() |>
  collect()
  
# Arrange grouped counts by ascending record count
galah_call() |>
  identify("Crinia") |>
  filter(year >= 2020) |>
  group_by(year) |>
  arrange(count) |>
  count() |>
  collect()
# Arrange grouped counts by descending year
galah_call() |>
  identify("Crinia") |>
  filter(year >= 2020) |>
  group_by(year) |>
  arrange(desc(year)) |>
  count() |>
  collect()
## End(Not run)
Retrieve a database query
Description
atlas_ functions retrieve data specified by the suffix of each function
name (e.g. atlas_counts(), atlas_occurrences()).
They are an alternative option to
using collect() at the
end of a query pipe. Using an atlas_ function or collect() at the end
of a query are basically synonymous,
but atlas_ functions differ in two ways:
- They have the ability to accept - filter,- selectetc as arguments, rather than within a pipe; but only when using the- galah_forms of those functions (e.g.- galah_filter()).
-  atlas_functions do not require you to specify themethodortypearguments togalah_call(), as they are more specific in what data are being requested.
Usage
atlas_occurrences(
  request = NULL,
  identify = NULL,
  filter = NULL,
  geolocate = NULL,
  data_profile = NULL,
  select = NULL,
  mint_doi = FALSE,
  doi = NULL,
  file = NULL
)
atlas_counts(
  request = NULL,
  identify = NULL,
  filter = NULL,
  geolocate = NULL,
  data_profile = NULL,
  group_by = NULL,
  limit = NULL,
  type = c("occurrences", "species")
)
atlas_species(
  request = NULL,
  identify = NULL,
  filter = NULL,
  geolocate = NULL,
  data_profile = NULL
)
atlas_media(
  request = NULL,
  identify = NULL,
  filter = NULL,
  select = NULL,
  geolocate = NULL,
  data_profile = NULL
)
atlas_taxonomy(
  request = NULL,
  identify = NULL,
  filter = NULL,
  constrain_ids = NULL
)
Arguments
| request | optional  | 
| identify | 
 | 
| filter | 
 | 
| geolocate | 
 | 
| data_profile | 
 | 
| select | 
 | 
| mint_doi | 
 | 
| doi | 
 | 
| file | 
 | 
| group_by | 
 | 
| limit | 
 | 
| type | 
 | 
| constrain_ids | 
 | 
Details
Note that unless care is taken, some queries can be particularly large.
While most cases this will simply take a long time to process, if the number
of requested records is >50 million, the call will not return any data. Users
can test whether this threshold will be reached by first calling
atlas_counts() using the same arguments that they intend to pass to
atlas_occurrences(). It may also be beneficial when requesting a large
number of records to show a progress bar by setting verbose = TRUE in
galah_config(), or to use compute() to run the call before collecting
it later with collect().
See ?collect_media() for more information on how to download media files.
Value
An object of class tbl_df and data.frame (aka a tibble). For
atlas_occurrences() and atlas_species(), this will have columns specified
by select(). For atlas_counts(),
it will have columns specified by
group_by().
Examples
## Not run: 
# Best practice is to first calculate the number of records
galah_call() |>
  filter(year == 2015) |>
  atlas_counts()
# Download occurrence records for a specific taxon
galah_config(email = "your_email_here") # login required for downloads
galah_call() |>
  identify("Reptilia") |>
  atlas_occurrences()
# Download occurrence records in a year range
galah_call() |>
  identify("Litoria") |>
  filter(year >= 2010 & year <= 2020) |>
  atlas_occurrences()
  
# Download occurrences records in a WKT-specified area
polygon <- "POLYGON((146.24960 -34.05930,
                     146.37045 -34.05930,
                     146.37045 -34.152549,
                     146.24960 -34.15254,
                     146.24960 -34.05930))"
galah_call() |> 
  identify("Reptilia") |>
  filter(year >= 2010, year <= 2020) |>
  st_crop(polygon) |>
  atlas_occurrences()
  
# Get a list of species within genus "Heleioporus"
# (every row is a species with associated taxonomic data)
galah_call() |>
  identify("Heleioporus") |>
  atlas_species()
# Download Regent Honeyeater records with multimedia attached
# Note this returns one row per multimedia file, NOT one per occurrence
# See `?collect_media()` for information on how to download media
galah_call() |>
  identify("Regent Honeyeater") |>
  filter(year == 2011) |>
  atlas_media()
# Get a taxonomic tree of *Chordata* down to the class level
galah_call() |> 
  identify("chordata") |>
  filter(rank == class) |>
  atlas_taxonomy()
## End(Not run)
Generate a citation for occurrence data
Description
If a tibble containing occurrences was generated using galah (either via
collect() or atlas_occurrences()), it
will usually contain associated metadata stored in attributes() that can be
used to build a citation for that dataset. This function simply extracts that
information, formats it, then both invisibly returns the formatted citation
and prints it to the console.
Usage
atlas_citation(data)
Arguments
| data | A  | 
Value
Invisibly returns a string containing the citation for that dataset. Primarily called for the side-effect of printing this string to the console.
Examples
## Not run: 
x <- galah_call() |>
    identify("Heleioporus") |>
    filter(year == 2022) |>
    collect()
atlas_citation(x)
## End(Not run)
Generate a query
Description
collapse() constructs a valid query so it can be
inspected before being sent. It typically occurs at the end of a pipe,
traditionally begun with galah_call(), that is used to define a query.
As of version 2.0, objects of class data_request (created using
request_data()), metadata_request (from request_metadata()) or
files_request (from request_files()) are all supported by collapse().
Any of these objects can be created using galah_call() via the method
argument.
Usage
## S3 method for class 'data_request'
collapse(x, ..., mint_doi, .expand = FALSE)
## S3 method for class 'metadata_request'
collapse(x, .expand = FALSE, ...)
## S3 method for class 'files_request'
collapse(x, thumbnail = FALSE, ...)
Arguments
| x | An object of class  | 
| ... | Arguments passed on to other methods | 
| mint_doi | Logical: should a DOI be minted for this download? Only
applies to  | 
| .expand | Logical: should the  | 
| thumbnail | Logical: should thumbnail-size images be returned? Defaults
to  | 
Value
An object of class query, which is a list-like object containing at
least the slots type and url.
Retrieve a database query
Description
collect() attempts to retrieve the result of a query from the
selected API.
Usage
## S3 method for class 'data_request'
collect(x, ..., wait = TRUE, file = NULL)
## S3 method for class 'metadata_request'
collect(x, ...)
## S3 method for class 'files_request'
collect(x, ...)
## S3 method for class 'query'
collect(x, ..., wait = TRUE, file = NULL)
## S3 method for class 'computed_query'
collect(x, ..., wait = TRUE, file = NULL)
Arguments
| x | An object of class  | 
| ... | Arguments passed on to other methods | 
| wait | logical; should  | 
| file | (Optional) file name. If not given, will be set to  | 
Value
In most cases, collect() returns a tibble containing requested
data. Where the requested data are not yet ready (i.e. for occurrences when
wait is set to FALSE), this function returns an object of class query
that can be used to recheck the download at a later time.
Collect media files
Description
This function downloads full-sized or thumbnail images and media files
to a local directory using information from atlas_media()
Usage
collect_media(df, thumbnail = FALSE, path)
Arguments
Value
Invisibly returns a tibble listing the number of files downloaded,
grouped by their HTML status codes. Primarily called for the side effect of
downloading available image & media files to a user local directory.
Examples
## Not run: 
# Use `atlas_media()` to return a `tibble` of records that contain media
x <- galah_call() |> 
  identify("perameles") |>
  filter(year == 2015) |>
  atlas_media()
# To download media files, add `collect_media()` to the end of a query 
galah_config(directory = "media_files")
collect_media(x)
# Since version 2.0, it is possible to run all steps in sequence
# first, get occurrences, making sure to include media fields:
occurrences_df <- request_data() |>
  identify("Regent Honeyeater") |>
  filter(!is.na(images), year == 2011) |>
  select(group = "media") |>
  collect()
 
# second, get media metadata
media_info <- request_metadata() |>
  filter(media == occurrences_df) |>
  collect()
  
# the two steps above + `right_join()` are synonymous with `atlas_media()`
# third, get images
request_files() |>
  filter(media == media_info) |>
  collect(thumbnail = TRUE)
# step three is synonymous with `collect_media()`
## End(Not run)
Compute a query
Description
compute() is useful for several purposes. It's original
purpose is to send a request for data, which can then be processed by the
server and retrieved at a later time (via collect()).
Usage
## S3 method for class 'data_request'
compute(x, ...)
## S3 method for class 'metadata_request'
compute(x, ...)
## S3 method for class 'files_request'
compute(x, ...)
## S3 method for class 'query'
compute(x, ...)
Arguments
| x | An object of class  | 
| ... | Arguments passed on to other methods | 
Value
An object of class computed_query, which is identical to class
query except for occurrence data, where it also contains information on the
status of the request.
Count the observations in each group
Description
count() lets you quickly count the unique values of one or more variables.
It is evaluated lazily.
Usage
## S3 method for class 'data_request'
count(x, ..., wt, sort, name)
Arguments
| x | An object of class  | 
| ... | currently ignored | 
| wt | currently ignored | 
| sort | currently ignored | 
| name | currently ignored | 
Keep rows that match a condition
Description
The filter() function is used to subset a data, retaining all rows that
satisfy your conditions. To be retained, the row must produce a value of
TRUE for all conditions. Unlike 'local' filters that act on a tibble,
the galah implementations work by amending a query which is then enacted
by collect() or one of the atlas_ family of functions (such as
atlas_counts() or atlas_occurrences()).
Usage
## S3 method for class 'data_request'
filter(.data, ...)
## S3 method for class 'metadata_request'
filter(.data, ...)
## S3 method for class 'files_request'
filter(.data, ...)
galah_filter(..., profile = NULL)
Arguments
| .data | An object of class  | 
| ... | Expressions that return a logical value, and are defined in terms
of the variables in the selected atlas (and checked using  | 
| profile | 
Details
Syntax
filter.data_request() and galah_filter() uses non-standard evaluation
(NSE), and are designed to be as compatible as possible with
dplyr::filter() syntax. Permissible examples include:
-  ==(e.g.year = 2020) but not=(for consistency withdplyr)
-  !=, e.g.year != 2020)
-  >or>=(e.g.year >= 2020)
-  <or<=(e.g.year <= 2020)
-  ORstatements (e.g.year == 2018 | year == 2020)
-  ANDstatements (e.g.year >= 2000 & year <= 2020)
Some general tips:
- Separating statements with a comma is equivalent to an - ANDstatement; Ergo- filter(year >= 2010 & year < 2020)is the same as- _filter(year >= 2010, year < 2020).
- All statements must include the field name; so - filter(year == 2010 | year == 2021)works, as does- filter(year == c(2010, 2021)), but- filter(year == 2010 | 2021)fails.
- It is possible to use an object to specify required values, e.g. - year_value <- 2010; filter(year > year_value).
-  solrsupports range queries on text as well as numbers; sofilter(cl22 >= "Tasmania")is valid.
- It is possible to filter by 'assertions', which are statements about data validity, such as - filter(assertions != c("INVALID_SCIENTIFIC_NAME", "COORDINATE_INVALID"). Valid assertions can be found using- show_all(assertions).
Exceptions
When querying occurrences, species, or their respective counts (i.e. all of
the above examples), field names are checked internally against
show_all(fields). There are some cases where bespoke field names are
required, as follows.
When requesting a data download from a DOI, the field doi is valid, i.e.:
galah_call() |> filter(doi = "a-long-doi-string") |> collect()
For taxonomic metadata, the taxa field is valid:
request_metadata() |> filter(taxa == "Chordata") |> unnest()
For building taxonomic trees, the rank field is valid:
request_data() |>
  identify("Chordata") |>
  filter(rank == "class") |>
  atlas_taxonomy()
Media queries are more involved, but break two rules: they accept the media
field, and they accept a tibble on the rhs of the equation. For example,
users wishing to break down media queries into their respective API calls
should begin with an occurrence query:
occurrences <- galah_call() |> 
   identify("Litoria peronii) |> 
   select(group = c("basic", "media") |> 
   collect()
They can then use the media field to request media metadata:
media_metadata <- galah_call("metadata") |>
  filter(media == occurrences) |>
  collect()
And finally, the metadata tibble can be used to request files:
galah_call("files") |>
  filter(media == media_metadata) |>
  collect()
Value
A tibble containing filter values.
See Also
select(),
group_by() and geolocate() for
other ways to amend the information returned by atlas_() functions. Use
search_all(fields) to find fields that you can filter by, and
show_values() to find what values of those filters are available.
Examples
## Not run: 
galah_call() |>
  filter(year >= 2019,
         basisOfRecord == "HumanObservation") |>
  count() |>
  collect()
## End(Not run)
Start building a query
Description
To download data from the selected atlas, one must construct a query. This
query tells the atlas API what data to download and return, as well as how it
should be filtered. Using galah_call() allows you to build a piped query to
download data, in the same way that you would wrangle data with dplyr and
the tidyverse.
Usage
galah_call(method = c("data", "metadata", "files"), type, ...)
request_data(
  type = c("occurrences", "occurrences-count", "occurrences-doi", "species",
    "species-count"),
  ...
)
request_metadata(
  type = c("fields", "apis", "assertions", "atlases", "collections", "datasets",
    "licences", "lists", "media", "profiles", "providers", "ranks", "reasons", "taxa",
    "identifiers")
)
request_files(type = "media")
Arguments
| method | string: what  | 
| type | string: what form of data should be returned? Acceptable values
are specified by the corresponding  | 
| ... | Zero or more arguments passed to
 | 
Details
In practice, galah_call() is a wrapper to a group of underlying
request_ functions, selected using the method argument.
Each of these functions can begin a piped query and end with collapse(),
compute() or collect(), or optionally one of the atlas_ family of
functions. For more details see the object-oriented programming vignette:
vignette("object_oriented_programming", package = "galah")
Accepted values of the type argument are set by the underlying request_
functions. While all accepted types can be set directly, some are affected
by later functions. The most common example is that adding
count() to a pipe updates type,
converting type = "occurrences" to type = "occurrences-count" (and ditto
for type = "species").
The underlying request_ functions are useful because they allow galah
to separate different types of requests to perform better. For example,
filter.data_request translates filters in R to solr, whereas
filter.metadata_request searches using a search term.
Value
Each sub-function returns a different object class: request_data()
returns data_request. request_metadata returns metadata_request,
request_files() returns files_request. These objects are list-like and
contain the following slots:
-  filter: edit by pipingfilter()orgalah_filter().
-  select: edit by pipingselectorgalah_select().
-  group_by: edit by pipinggroup_by()orgalah_group_by().
-  identify: edit by pipingidentify()orgalah_identify().
-  geolocate: edit by pipingst_crop(),galah_geolocate(),galah_polygon()orgalah_bbox().
-  limit: edit by pipingslice_head().
-  doi: edit by pipingfilter(doi == "my-doi-here").
See Also
collapse.data_request(), compute.data_request(), collect.data_request()
Examples
## Not run:  
# Begin your query with `galah_call()`, then pipe using `%>%` or `|>`
# Get number of records of *Aves* from 2001 to 2004 by year
galah_call() |>
  identify("Aves") |>
  filter(year > 2000 & year < 2005) |>
  group_by(year) |>
  atlas_counts()
  
# Get information for all species in *Cacatuidae* family
galah_call() |>
  identify("Cacatuidae") |>
  atlas_species()
  
# Download records of genus *Eolophus* from 2001 to 2004
galah_config(email = "your-email@email.com")
galah_call() |>
  identify("Eolophus") |>
  filter(year > 2000 & year < 2005) |>
  atlas_occurrences() # synonymous with `collect()`
# galah_call() is a wrapper to various `request_` functions.
# These can be called directly for greater specificity.
# Get number of records of *Aves* from 2001 to 2004 by year
request_data() |>
  identify("Aves") |>
  filter(year > 2000 & year < 2005) |>
  group_by(year) |>
  count() |>
  collect()
# Get information for all species in *Cacatuidae* family
request_data(type = "species") |>
  identify("Cacatuidae") |>
  collect()
  
# Get metadata information about supported atlases in galah
request_metadata(type = "atlases") |>
  collect()
## End(Not run)
Get or set configuration options that control galah behaviour
Description
The galah package supports large data downloads, and also
interfaces with the ALA which requires that users of some services
provide a registered email address and reason for downloading data. The
galah_config function provides a way to manage these issues as simply
as possible.
Usage
galah_config(...)
Arguments
| ... | Options can be defined using the form  
 | 
Value
For galah_config(), a list of all options.
When galah_config(...) is called with arguments, nothing is returned
but the configuration is set.
Examples
## Not run: 
# To download occurrence records, enter your email in `galah_config()`. 
# This email should be registered with the atlas in question. 
galah_config(email = "your-email@email.com")
 
# Turn on caching in your session
galah_config(caching = TRUE)
 
# Some ALA services require that you add a reason for downloading data. 
# Add your selected reason using the option `download_reason_id`
galah_config(download_reason_id = 0)
# To look up all valid reasons to enter, use `show_all(reasons)`
show_all(reasons)
# Make debugging in your session easier by setting `verbose = TRUE`
galah_config(verbose = TRUE)
## End(Not run)
Narrow a query to within a specified area
Description
Restrict results to those from a specified area.
Areas can be specified as either polygons or bounding boxes, depending on
type. Alternatively, users can call the underlying functions directly via
galah_polygon(), galah_bbox() or galah_radius(). It is possible to use
sf syntax by calling st_crop(), which is synonymous with
galah_polygon().
Use a polygon
If calling galah_geolocate(), the default type is "polygon", which
narrows queries to within an area supplied as a POLYGON or MULTIPOLYGON.
Polygons must be
specified as either an sf object, a 'well-known text' (WKT) string, or a
shapefile. Shapefiles must be simple to be accepted by the ALA.
Use a bounding box
Alternatively, set type = "bbox" to narrow queries to within a bounding
box. Bounding boxes can be extracted from a supplied sf object or
a shapefile. A bounding box can also be supplied as a bbox object
(via sf::st_bbox()) or a tibble/data.frame.
Use a point radius
Alternatively, set 
type = "radius" to narrow queries to within a circular
area around a specific point location. Point coordinates can be supplied as
latitude/longitude coordinate numbers or as an sf object (sfc_POINT).
Area is supplied as a radius in kilometres. Default radius is 10 km.
Usage
geolocate(..., type = c("polygon", "bbox", "radius"))
galah_geolocate(..., type = c("polygon", "bbox", "radius"))
galah_polygon(...)
galah_bbox(...)
galah_radius(...)
## S3 method for class 'data_request'
st_crop(x, y, ...)
Arguments
| ... | For  | 
| type | 
 | 
| x | An object of class  | 
| y | A valid Well-Known Text string (wkt), a  | 
Details
If type = "polygon", WKT strings longer than 10000 characters and
sf objects with more than 500 vertices will not be
accepted by the ALA. Some polygons  may need to be simplified.
If type = "bbox", sf objects and shapefiles will be converted to a bounding
box to query the ALA.
If type = "radius, sfc_POINT objects will be converted to lon/lat
coordinate numbers to query the ALA. Default radius is 10 km.
Value
If type = "polygon" or type = "bbox",
length-1 string (class character) containing a multipolygon WKT
string representing the area provided.
If type = "radius",
list of lat, long and radius values.
Examples
## Not run: 
# Search for records within a polygon using a shapefile
location <- sf::st_read("path/to/shapefile.shp")
galah_call() |>
  identify("vulpes") |>
  geolocate(location) |>
  count() |>
  collect()
  
# Search for records within the bounding box of a shapefile
location <- sf::st_read("path/to/shapefile.shp")
galah_call() |>
  identify("vulpes") |>
  geolocate(location, type = "bbox") |>
  count() |>
  collect()
# Search for records within a polygon using an `sf` object
location <- "POLYGON((142.3 -29.0,142.7 -29.1,142.7 -29.4,142.3 -29.0))" |>
 sf::st_as_sfc()
galah_call() |>
  identify("reptilia") |>
  galah_polygon(location) |>
  count() |>
  collect()
  
# Search for records using a Well-known Text string (WKT)
wkt <- "POLYGON((142.3 -29.0,142.7 -29.1,142.7 -29.4,142.3 -29.0))"
galah_call() |>
  identify("vulpes") |>
  st_crop(wkt) |>
  count() |>
  collect()
# Search for records within the bounding box extracted from an `sf` object
location <- "POLYGON((142.3 -29.0,142.7 -29.1,142.7 -29.4,142.3 -29.0))" |>
  sf::st_as_sfc()
galah_call() |>
  identify("vulpes") |>
  galah_geolocate(location, type = "bbox") |>
  count() |>
  collect()
# Search for records using a bounding box of coordinates
b_box <- sf::st_bbox(c(xmin = 143, xmax = 148, ymin = -29, ymax = -28), 
                     crs = sf::st_crs("WGS84"))
galah_call() |>
  identify("reptilia") |>
  galah_geolocate(b_box, type = "bbox") |>
  count() |>
  collect()
# Search for records using a bounding box in a `tibble` or `data.frame`
b_box <- tibble::tibble(xmin = 148, ymin = -29, xmax = 143, ymax = -21)
galah_call() |>
  identify("vulpes") |>
  galah_geolocate(b_box, type = "bbox") |>
  count() |>
  collect()
# Search for records within a radius around a point's coordinates
galah_call() |>
  identify("manorina melanocephala") |>
  galah_geolocate(lat = -33.7,
                  lon = 151.3,
                  radius = 5,
                  type = "radius") |>
  count() |>
  collect()
# Search for records with a radius around an `sf_POINT` object
point <- sf::st_sfc(sf::st_point(c(-33.66741, 151.3174)), crs = 4326)
galah_call() |>
  identify("manorina melanocephala") |>
  galah_geolocate(point,
                  radius = 5,
                  type = "radius") |>
  count() |>
  collect()
## End(Not run)
Group by one or more variables
Description
Most data operations are done on groups defined by variables. group_by()
takes a field name (unquoted) and performs a grouping operation. The default
behaviour is to use it in combination with
count() to give information on number
of occurrences per level of that field. Alternatively, you can use it
without count to get a download of occurrences grouped by that variable. This
is particularly useful when used with a taxonomic ID field (speciesID,
genusID etc.) as it allows further information to be appended to the result.
This is how atlas_species() works, for example. See
select() for details.
Usage
## S3 method for class 'data_request'
group_by(.data, ...)
galah_group_by(...)
Arguments
| .data | An object of class  | 
| ... | Zero or more individual column names to include | 
Value
If any arguments are provided, returns a data.frame with
columns name and type, as per select.data_request().
Examples
## Not run: 
# default usage is for grouping counts
galah_call() |> 
  group_by(basisOfRecord) |>
  counts() |>
  collect()
# Alternatively, we can use this with an occurrence search  
galah_call() |>
  filter(year == 2024,
         genus = "Crinia") |>
  group_by(speciesID) |>
 collect()
# note that this example is equivalent to `atlas_species()`; 
# but using `group_by()` is more flexible.
## End(Not run)
Narrow a query by passing taxonomic identifiers
Description
When conducting a search or creating a data query, it is common to identify
a known taxon or group of taxa to narrow down the records or results returned.
identify() is used to identify taxa you want returned in a search or
a data query. Users to pass scientific names or taxonomic identifiers
with pipes to provide data only for the biological group of interest.
It is good to use search_taxa() and search_identifiers()
first to check that the taxa you provide to galah_identify() return the
correct results.
Usage
## S3 method for class 'data_request'
identify(x, ...)
## S3 method for class 'metadata_request'
identify(x, ...)
galah_identify(..., search = NULL)
Arguments
| x | An object of class  | 
| ... | One or more scientific names. | 
| search | 
 | 
Value
A tibble containing identified taxa.
See Also
filter() or geolocate() for
other ways to filter a query. You can also use search_taxa() to check that
supplied names are being matched correctly on the server-side; see
taxonomic_searches for a detailed overview.
Examples
## Not run: 
# Use `galah_identify()` to narrow your queries
galah_call() |> 
  identify("Eolophus") |>
  count() |>
  collect()
# If you know a valid taxon identifier, use `filter()` instead.
id <- "https://biodiversity.org.au/afd/taxa/009169a9-a916-40ee-866c-669ae0a21c5c"
galah_call() |> 
  filter(lsid == id)  |>
  count() |>
  collect()
## End(Not run)
Print galah objects
Description
As of version 2.0, galah supports several bespoke object types. Classes
data_request, metadata_request and files_request are for starting pipes
to download different types of information. These objects are parsed using
collapse() into a query object, which contains one or more URLs necessary
to return the requested information. This object is then passed to
compute() and/or collect(). Finally, galah_config() creates an object
of class galah_config which (unsurprisingly) stores configuration
information.
Usage
## S3 method for class 'data_request'
print(x, ...)
## S3 method for class 'files_request'
print(x, ...)
## S3 method for class 'metadata_request'
print(x, ...)
## S3 method for class 'query'
print(x, ...)
## S3 method for class 'computed_query'
print(x, ...)
## S3 method for class 'query_set'
print(x, ...)
## S3 method for class 'galah_config'
print(x, ...)
Arguments
| x | an object of the appropriate  | 
| ... | Arguments to be passed to or from other methods | 
Value
Print does not return an object; instead it prints a description of the object to the console
Examples
## Not run: 
# The most common way to start a pipe is with `galah_call()`
# later functions update the `data_request` object
galah_call() |> # same as calling `request_data()`
  filter(year >= 2020) |>
  group_by(year) |>
  count()
# Metadata requests are formatted in a similar way
request_metadata() |>
  filter(field == basisOfRecord) |>
  unnest()
# Queries are converted into a `query_set` by `collapse()`
x <- galah_call() |> # same as calling `request_data()`
  filter(year >= 2020) |>
  count() |>
  collapse()
print(x)
  
# Each `query_set` contains one or more `query` objects
x[[3]]
## End(Not run)
Read downloaded data from a zip file
Description
Living atlases supply data downloads as zip files. This function reads these
data efficiently, i.e. without unzipping them first, using the readr
package. Although this function has been part of galah for some time, it was
previously internal to atlas_occurrences(). It has been exported now to
support easy re-importing of downloaded files, without the need to re-run
a query.
Usage
read_zip(file)
Arguments
| file | (character) A file name. Must be a length-1 character ending in
 | 
Examples
## Not run: 
# set a working directory
galah_config(directory = "data-raw",
             email = "an-email-address@email.com")
# download some data
galah_call() |>
  identify("Heleioporus") |>
  filter(year == 2022) |>
  collect(file = "burrowing_frog_data.zip")
  
# load data from file
x <- read_zip("./data-raw/burrowing_frog_data.zip")
## End(Not run)
Objects exported from other packages
Description
These objects are imported from other packages. Follow the links below to see their documentation.
Search for record information
Description
The living atlases store a huge amount of information, above and beyond the
occurrence records that are their main output. In galah, one way that
users can investigate this information is by searching for a specific option
or category for the type of information they are interested in.
Functions prefixed with search_ do this, displaying any matches to a
search term within the valid options for the information specified by the
suffix.
For more information about taxonomic searches using search_taxa(), see ?taxonomic_searches.
search_all() is a helper function that can do searches for multiple
types of information, acting as a wrapper around many search_ sub-functions.
See Details (below) for accepted values.
Usage
search_all(type, query)
search_assertions(query)
search_apis(query)
search_atlases(query)
search_collections(query)
search_datasets(query)
search_fields(query)
search_identifiers(...)
search_licences(query)
search_lists(query)
search_profiles(query)
search_providers(query)
search_ranks(query)
search_reasons(query)
search_taxa(...)
Arguments
| type | A string to specify what type of parameters should be searched. | 
| query | A string specifying a search term. Searches are not case-sensitive. | 
| ... | A set of strings or a tibble to be queried; see Details. | 
Details
There are five categories of information, each with their own
specific sub-functions to look-up each type of information.
The available types of information for search_all() are:
| Category | Type | Description | Sub-functions | 
| configuration | atlases | Search for what atlases are available | search_atlases() | 
| apis | Search for what APIs & functions are available for each atlas | search_apis() | |
| reasons | Search for what values are acceptable as 'download reasons' for a specified atlas | search_reasons() | |
| taxonomy | taxa | Search for one or more taxonomic names | search_taxa() | 
| identifiers | Take a universal identifier and return taxonomic information | search_identifiers() | |
| ranks | Search for valid taxonomic ranks (e.g. Kingdom, Class, Order, etc.) | search_ranks() | |
| filters | fields | Search for fields that are stored in an atlas | search_fields() | 
| assertions | Search for results of data quality checks run by each atlas | search_assertions() | |
| licenses | Search for copyright licences applied to media | search_licenses() | |
| group filters | profiles | Search for what data profiles are available | search_profiles() | 
| lists | Search for what species lists are available | search_lists() | |
| data providers | providers | Search for which institutions have provided data | search_providers() | 
| collections | Search for the specific collections within those institutions | search_collections() | |
| datasets | Search for the data groupings within those collections | search_datasets() | |
Value
An object of class tbl_df and data.frame (aka a tibble)
containing all data that match the search query.
See Also
Use the show_all() function and show_all_() sub-functions to
show available options of information. These functions are used to pass valid
arguments to filter(),
select(), and related functions.
Taxonomic queries are somewhat more involved; see taxonomic_searches for
details.
Examples
## Not run: 
# Search for fields that include the word "date"
search_all(fields, "date")
# Search for fields that include the word "marine"
search_all(fields, "marine")
# Search using a single taxonomic term
# (see `?search_taxa()` for more information)
search_all(taxa, "Reptilia") # equivalent
# Look up a unique taxon identifier
# (see `?search_identifiers()` for more information)
search_all(identifiers, 
           "https://id.biodiversity.org.au/node/apni/2914510")
# Search for species lists that match "endangered"
search_all(lists, "endangered") # equivalent
# Search for a valid taxonomic rank, "subphylum"
search_all(ranks, "subphylum")
# An alternative is to download the data and then `filter` it. This is 
# largely synonymous, and allows greater control over which fields are searched.
request_metadata(type = "fields") |>
 collect() |>
 dplyr::filter(grepl("date", id))
## End(Not run)
Keep or drop columns using their names
Description
Select (and optionally rename) variables in a data frame, using
a concise mini-language that makes it easy to refer to variables based on
their name. Note that unlike calling select() on a local tibble, this
implementation is only evaluated at the
collapse() stage, meaning any errors
or messages will be triggered at the end of the pipe.
select() supports dplyr selection helpers, including:
-  everything: Matches all variables.
-  last_col: Select last variable, possibly with an offset.
Other helpers select variables by matching patterns in their names:
-  starts_with: Starts with a prefix.
-  ends_with: Ends with a suffix.
-  contains: Contains a literal string.
-  matches: Matches a regular expression.
-  num_range: Matches a numerical range like x01, x02, x03.
Or from variables stored in a character vector:
-  all_of: Matches variable names in a character vector. All names must be present, otherwise an out-of-bounds error is thrown.
-  any_of: Same asall_of(), except that no error is thrown for names that don't exist.
Or using a predicate function:
-  where: Applies a function to all variables and selects those for which the function returnsTRUE.
Usage
## S3 method for class 'data_request'
select(.data, ..., group)
galah_select(..., group)
Arguments
| .data | An object of class  | 
| ... | Zero or more individual column names to include. | 
| group | 
 | 
Details
GBIF nodes store content in hundreds of different fields, and users often
require thousands or millions of records at a time. To reduce time taken to
download data, and limit complexity of the resulting tibble, it is sensible
to restrict the fields returned by occurrence queries. The full list of
available fields can be viewed with show_all(fields). Note that select()
and galah_select() are supported for all atlases that allow downloads, with
the exception of GBIF, for which all columns are returned.
Calling the argument group = "basic" returns the following columns:
-  decimalLatitude
-  decimalLongitude
-  eventDate
-  scientificName
-  taxonConceptID
-  recordID
-  dataResourceName
-  occurrenceStatus
Using group = "event" returns the following columns:
-  eventRemarks
-  eventTime
-  eventID
-  eventDate
-  samplingEffort
-  samplingProtocol
Using group = "media" returns the following columns:
-  multimedia
-  multimediaLicence
-  images
-  videos
-  sounds
Using group = "taxonomy" returns higher taxonomic information for a given
query. It is the only group that is accepted by atlas_species() as well
as atlas_occurrences().
Using group = "assertions" returns all quality assertion-related
columns. The list of assertions is shown by show_all_assertions().
For atlas_occurrences(), arguments passed to ... should be valid field
names, which you can check using show_all(fields). For atlas_species(),
it should be one or more of:
-  countsto include counts of occurrences per species.
-  synonymsto include any synonymous names.
-  liststo include authoritative lists that each species is included on.
Value
A tibble
specifying the name and type of each column to include in the
call to atlas_counts() or atlas_occurrences().
See Also
filter(),
st_crop() and
identify() for other ways to restrict
the information returned; show_all(fields) to list available fields.
Examples
## Not run: 
# Download occurrence records of *Perameles*, 
# Only return scientificName and eventDate columns
galah_config(email = "your-email@email.com")
galah_call() |>
  identify("perameles")|>
  select(scientificName, eventDate) |>
  collect()
# Only return the "basic" group of columns and the basisOfRecord column
galah_call() |>
  identify("perameles") |>
  select(basisOfRecord, group = "basic") |>
  collect()
  
# When used in a pipe, `galah_select()` and `select()` are synonymous.
# Hence the previous example can be rewritten as:
galah_call() |>
  galah_identify("perameles") |>
  galah_select(basisOfRecord, group = "basic") |>
  collect()
## End(Not run)
Show valid record information
Description
The living atlases store a huge amount of information, above and beyond the
occurrence records that are their main output. In galah, one way that
users can investigate this information is by showing all the available
options or categories for the type of information they are interested in.
Functions prefixed with show_all_ do this, displaying all valid options
for the information specified by the suffix.
show_all() is a helper function that can display multiple types of
information from show_all_ sub-functions.
Usage
show_all(..., limit = NULL)
show_all_apis(limit = NULL)
show_all_assertions(limit = NULL)
show_all_atlases(limit = NULL)
show_all_collections(limit = NULL)
show_all_datasets(limit = NULL)
show_all_fields(limit = NULL)
show_all_licences(limit = NULL)
show_all_lists(limit = NULL)
show_all_profiles(limit = NULL)
show_all_providers(limit = NULL)
show_all_ranks(limit = NULL)
show_all_reasons(limit = NULL)
Arguments
| ... | String showing what type of information is to be requested. See
 | 
| limit | Optional number of values to return. Defaults to NULL, i.e. all records | 
Details
There are five categories of information, each with their own
specific sub-functions to look-up each type of information.
The available types of information for show_all_ are:
| Category | Type | Description | Sub-functions | 
| Configuration | atlases | Show what atlases are available | show_all_atlases() | 
| apis | Show what APIs & functions are available for each atlas | show_all_apis() | |
| reasons | Show what values are acceptable as 'download reasons' for a specified atlas | show_all_reasons() | |
| Data providers | providers | Show which institutions have provided data | show_all_providers() | 
| collections | Show the specific collections within those institutions | show_all_collections() | |
| datasets | Shows all the data groupings within those collections | show_all_datasets() | |
| Filters | assertions | Show results of data quality checks run by each atlas | show_all_assertions() | 
| fields | Show fields that are stored in an atlas | show_all_fields() | |
| licenses | Show what copyright licenses are applied to media | show_all_licenses() | |
| profiles | Show what data profiles are available | show_all_profiles() | |
| Taxonomy | lists | Show what species lists are available | show_all_lists() | 
| ranks | Show valid taxonomic ranks (e.g. Kingdom, Class, Order, etc.) | show_all_ranks() | |
Value
An object of class tbl_df and data.frame (aka a tibble)
containing all data of interest.
References
- Darwin Core terms https://dwc.tdwg.org/terms/ 
See Also
Use the search_all() function and search_() sub-functions to
search for information. These functions are used to pass valid arguments to
filter(),
select(), and related functions.
Examples
## Not run: 
# See all supported atlases
show_all(atlases)
# Show a list of all available data quality profiles
show_all(profiles)
# Show a listing of all accepted reasons for downloading occurrence data
show_all(reasons)
# Show a listing of all taxonomic ranks
show_all(ranks)
# `show_all()` is synonymous with `request_metadata() |> collect()`
request_metadata(type = "fields") |>
  collect()
## End(Not run)
Show or search for values within a specified field
Description
Users may wish to see the specific values within a chosen field, profile
or list to narrow queries or understand more about the information of
interest. show_values() provides users with these values. search_values()
allows users for search for specific values within a specified field.
Usage
show_values(df, all_fields = FALSE)
search_values(df, query)
Arguments
| df | A search result from  | 
| all_fields | 
 | 
| query | A string specifying a search term. Not case sensitive. | 
Details
Each Field contains categorical or numeric values. For example:
- The - field"year" contains values 2021, 2020, 2019, etc.
- The - field"stateProvince" contains values New South Wales, Victoria, Queensland, etc. These are used to narrow queries with- filter()or- galah_filter().
Each Profile consists of many individual quality filters. For example, the "ALA" profile consists of values:
- Exclude all records where spatial validity is FALSE 
- Exclude all records with a latitude value of zero 
- Exclude all records with a longitude value of zero 
Each List contains a list of species, usually by taxonomic name. For example, the Endangered Plant species list contains values:
- Acacia curranii (Curly-bark Wattle) 
- Brachyscome papillosa (Mossgiel Daisy) 
- Solanum karsense (Menindee Nightshade) 
Value
A tibble of values for a specified field, profile or list.
Examples
## Not run: 
# Show values in field 'cl22'
search_fields("cl22") |> 
  show_values()
# This is synonymous with `request_metadata() |> unnest()`.
# For example, the previous example can be run using:
request_metadata() |>
  filter(field == "cl22") |>
  unnest() |>
  collect() 
# Search for any values in field 'cl22' that match 'tas'
search_fields("cl22") |> 
  search_values("tas")
# See items within species list "dr19257"
search_lists("dr19257") |> 
  show_values()
## End(Not run)
Subset rows using their positions
Description
slice() lets you index rows by their (integer) locations. For objects of
classes data_request or metadata_request, only slice_head() is
currently implemented, and selects the first n rows.
If .data has been grouped using
group_by(), the operation will be
performed on each group, so that (e.g.) slice_head(df, n = 5) will select
the first five rows in each group.
Usage
## S3 method for class 'data_request'
slice_head(.data, ..., n, prop, by = NULL)
## S3 method for class 'metadata_request'
slice_head(.data, ..., n, prop, by = NULL)
Arguments
| .data | An object of class  | 
| ... | Currently ignored | 
| n | The number of rows to be returned. If data are grouped
 | 
| prop | Currently ignored. | 
| by | Currently ignored. | 
Value
An amended data_request with a completed slice slot.
Examples
## Not run: 
# Limit number of rows returned to 3.
# In this case, our query returns the top 3 years with most records.
galah_call() |>
  identify("perameles") |>
  filter(year > 2010) |>
  group_by(year) |>
  count() |>
  slice_head(n = 3) |>
  collect()
## End(Not run)
Look up taxon information
Description
search_taxa() allows users to look up taxonomic names, and ensure they are
being matched correctly, before downloading data from the specified
organisation.
By default, names are supplied as strings; but users can also specify
taxonomic levels in a search using a data.frame or tibble. This is useful
when the taxonomic level of the name in question needs to be specified,
in addition to it's identity. For example, a common method is to use the
scientificName column to list a Latinized binomial, but it is also possible
to list these separately under genus and specificEpithet (respectively).
A more common use-case is to distinguish between homonyms by listing higher
taxonomic units, by supplying columns like kingdom, phylum or class.
search_identifiers() allows users to look up matching taxonomic names using
their unique taxonConceptID. In the ALA, all records are associated with
an identifier that uniquely identifies the taxon to which that record belongs.
Once those identifiers are known, this function allows you to use them to
look up further information on the taxon in question. Effectively this is the
inverse function to search_taxa(), which takes names and provides
identifiers.
Note that when taxonomic look-up is required within a pipe, the equivalent
to search_taxa() is identify() (or
galah_identify()). The equivalent to search_identifiers() is to use
filter() to filter by taxonConceptId.
Details
search_taxa() returns the taxonomic match of a supplied text string, along
with the following information:
-  search_term: The search term used by the user. When multiple search terms are provided in a tibble, these are displayed in this column, concatenated using_.
-  scientific_name: The taxonomic name matched to the provided search term, to the lowest identified taxonomic rank.
-  taxon_concept_id: The unique taxonomic identifier.
-  rank: The taxonomic rank of the returned result.
-  match_type: (ALA only) The method of name matching used by the name matching service. More information can be found on the name matching github repository.
-  issues: Any errors returned by the name matching service (e.g. homonym, indeterminate species match). More information can be found on the name matching github repository.
-  taxonomic names(e.g.kingdom,phylum,class,order,family,genus)
See Also
search_all() for how to get names if taxonomic identifiers
are already known. filter(),
select(),
identify() and geolocate() for ways
to restrict the information returned by atlas_() functions.
Examples
## Not run: 
# Search using a single string. 
# Note that `search_taxa()` is not case sensitive
search_taxa("Reptilia")
# Search using multiple strings. 
# `search_taxa()` will return one row per taxon
search_taxa("reptilia", "mammalia")
# Search using more detailed strings with authorship information
search_taxa("Acanthocladium F.Muell")
# Specify taxonomic levels in a tibble using "specificEpithet"
search_taxa(tibble::tibble(
  class = "aves", 
  family = "pardalotidae", 
  genus = "pardalotus", 
  specificEpithet = "punctatus"))
# Specify taxonomic levels in a tibble using "scientificName"                    
search_taxa(tibble::tibble(
  family = c("pardalotidae", "maluridae"), 
  scientificName = c("Pardalotus striatus striatus", "malurus cyaneus")))
# Look up a unique taxon identifier
search_identifiers(query = "https://id.biodiversity.org.au/node/apni/2914510")
## End(Not run)
Non-generic tidyverse functions
Description
Several useful functions from tidyverse packages are generic, meaning
that we can define class-specific versions of those functions and implement
them in galah; examples include filter(), select() and group_by().
However, there are also functions that are only defined within tidyverse
packages and are not generic. In a few cases we have re-implemented these
functions in galah. This has the consequence of supporting consistent
syntax with tidyverse, at the cost of potentially introducing conflicts.
This can be avoided by using the :: operator where required (see examples).
Usage
desc(...)
unnest(.query)
Arguments
| ... | column to order by | 
| .query | An object of class  | 
Details
The following functions are included:
-  desc()(dplyr): Use withinarrange()to specify arrangement should be descending
-  unnest()(tidyr): Use to 'drill down' into nested information onfields,lists,profiles, ortaxa
These galah versions all use lazy evaluation.
Value
-  galah::desc()returns atibbleused byarrange.data_request()to arrange rows of a query.
-  galah::unnest()returns an object of classmetadata_request.
See Also
Examples
## Not run: 
# Arrange grouped record counts by descending year
galah_call() |>
  identify("perameles") |>
  filter(year > 2019) |>
  count() |>
  arrange(galah::desc(year)) |>
  collect()
# Return values of field `basisOfRecord`
request_metadata() |> 
  galah::unnest() |> 
  filter(field == basisOfRecord) |> 
  collect()
  
# Using `galah::unnest()` in this way is equivalent to:
show_all(fields, "basisOfRecord") |> 
  show_values()
## End(Not run)