Title: | A Robust Interface to ArcGIS 'Geocoding Services' |
---|---|
Description: | A very fast and robust interface to ArcGIS 'Geocoding Services'. Provides capabilities for reverse geocoding, finding address candidates, character-by-character search autosuggestion, and batch geocoding. The public 'ArcGIS World Geocoder' is accessible for free use via 'arcgisgeocode' for all services except batch geocoding. 'arcgisgeocode' also integrates with 'arcgisutils' to provide access to custom locators or private 'ArcGIS World Geocoder' hosted on 'ArcGIS Enterprise'. Learn more in the 'Geocode service' API reference <https://developers.arcgis.com/rest/geocode/api-reference/overview-world-geocoding-service.htm>. |
Authors: | Josiah Parry [aut, cre] |
Maintainer: | Josiah Parry <[email protected]> |
License: | Apache License (>= 2) |
Version: | 0.2.2 |
Built: | 2025-01-21 17:30:40 UTC |
Source: | https://github.com/r-arcgis/arcgisgeocode |
An integer vector containing the WKIDs of Esri authority
spatial references.
Esri WKIDs were identified from the {arcgeocoder}
package from
@dieghernan.
esri_wkids
esri_wkids
An object of class integer
of length 2886.
a numeric vector of well-known IDs
Given an address, returns geocode result candidates.
find_address_candidates( single_line = NULL, address = NULL, address2 = NULL, address3 = NULL, neighborhood = NULL, city = NULL, subregion = NULL, region = NULL, postal = NULL, postal_ext = NULL, country_code = NULL, search_extent = NULL, location = NULL, category = NULL, crs = NULL, max_locations = NULL, for_storage = FALSE, match_out_of_range = NULL, location_type = NULL, lang_code = NULL, source_country = NULL, preferred_label_values = NULL, magic_key = NULL, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
find_address_candidates( single_line = NULL, address = NULL, address2 = NULL, address3 = NULL, neighborhood = NULL, city = NULL, subregion = NULL, region = NULL, postal = NULL, postal_ext = NULL, country_code = NULL, search_extent = NULL, location = NULL, category = NULL, crs = NULL, max_locations = NULL, for_storage = FALSE, match_out_of_range = NULL, location_type = NULL, lang_code = NULL, source_country = NULL, preferred_label_values = NULL, magic_key = NULL, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
single_line |
a character vector of addresses to geocode. If provided
other |
address |
a character vector of the first part of a street address.
Typically used for the street name and house number. But can also be a place
or building name. If |
address2 |
a character vector of the second part of a street address. Typically includes a house number, sub-unit, street, building, or place name. Optional. |
address3 |
a character vector of the third part of an address. Optional. |
neighborhood |
a character vector of the smallest administrative division associated with an address. Typically, a neighborhood or a section of a larger populated place. Optional. |
city |
a character vector of the next largest administrative division associated with an address, typically, a city or municipality. A city is a subdivision of a subregion or a region. Optional. |
subregion |
a character vector of the next largest administrative division associated with an address. Depending on the country, a subregion can represent a county, state, or province. Optional. |
region |
a character vector of the largest administrative division associated with an address, typically, a state or province. Optional. |
postal |
a character vector of the standard postal code for an address, typically, a three– to six-digit alphanumeric code. Optional. |
postal_ext |
a character vector of the postal code extension, such as the United States Postal Service ZIP+4 code, provides finer resolution or higher accuracy when also passing postal. Optional. |
country_code |
default |
search_extent |
an object of class |
location |
an |
category |
a scalar character. Place or address type that can be used to filter suggest results. Optional. |
crs |
the CRS of the returned geometries. Passed to |
max_locations |
the maximum number of results to return. The default is 15 with a maximum of 50. Optional. |
for_storage |
default |
match_out_of_range |
set to |
location_type |
default |
lang_code |
default |
source_country |
default |
preferred_label_values |
default NULL. Must be one of |
magic_key |
a unique identifier returned from |
geocoder |
default |
token |
an object of class |
.progress |
default |
Utilizes the /findAddressCandidates
endpoint.
The endpoint can only handle one request at a time. To
make the operation as performant as possible, requests are sent in parallel
using httr2::req_perform_parallel()
. The JSON responses are then processed
using Rust and returned as an sf object.
An sf
object with 60 columns.
candidates_from_single <- find_address_candidates( single_line = "Bellwood Coffee, 1366 Glenwood Ave SE, Atlanta, GA, 30316, USA" ) candidates_from_parts <- find_address_candidates( address = c("Bellwood Coffee", "Joe's coffeehouse"), address2 = c("1366 Glenwood Ave SE", "510 Flat Shoals Ave"), city = "Atlanta", region = "GA", postal = "30316", country_code = "USA" ) str(candidates_from_parts)
candidates_from_single <- find_address_candidates( single_line = "Bellwood Coffee, 1366 Glenwood Ave SE, Atlanta, GA, 30316, USA" ) candidates_from_parts <- find_address_candidates( address = c("Bellwood Coffee", "Joe's coffeehouse"), address2 = c("1366 Glenwood Ave SE", "510 Flat Shoals Ave"), city = "Atlanta", region = "GA", postal = "30316", country_code = "USA" ) str(candidates_from_parts)
Gecocode a vector of addresses in batches.
geocode_addresses( single_line = NULL, address = NULL, address2 = NULL, address3 = NULL, neighborhood = NULL, city = NULL, subregion = NULL, region = NULL, postal = NULL, postal_ext = NULL, country_code = NULL, location = NULL, search_extent = NULL, category = NULL, crs = NULL, max_locations = NULL, for_storage = FALSE, match_out_of_range = NULL, location_type = NULL, lang_code = NULL, source_country = NULL, preferred_label_values = NULL, batch_size = NULL, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
geocode_addresses( single_line = NULL, address = NULL, address2 = NULL, address3 = NULL, neighborhood = NULL, city = NULL, subregion = NULL, region = NULL, postal = NULL, postal_ext = NULL, country_code = NULL, location = NULL, search_extent = NULL, category = NULL, crs = NULL, max_locations = NULL, for_storage = FALSE, match_out_of_range = NULL, location_type = NULL, lang_code = NULL, source_country = NULL, preferred_label_values = NULL, batch_size = NULL, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
single_line |
a character vector of addresses to geocode. If provided
other |
address |
a character vector of the first part of a street address.
Typically used for the street name and house number. But can also be a place
or building name. If |
address2 |
a character vector of the second part of a street address. Typically includes a house number, sub-unit, street, building, or place name. Optional. |
address3 |
a character vector of the third part of an address. Optional. |
neighborhood |
a character vector of the smallest administrative division associated with an address. Typically, a neighborhood or a section of a larger populated place. Optional. |
city |
a character vector of the next largest administrative division associated with an address, typically, a city or municipality. A city is a subdivision of a subregion or a region. Optional. |
subregion |
a character vector of the next largest administrative division associated with an address. Depending on the country, a subregion can represent a county, state, or province. Optional. |
region |
a character vector of the largest administrative division associated with an address, typically, a state or province. Optional. |
postal |
a character vector of the standard postal code for an address, typically, a three– to six-digit alphanumeric code. Optional. |
postal_ext |
a character vector of the postal code extension, such as the United States Postal Service ZIP+4 code, provides finer resolution or higher accuracy when also passing postal. Optional. |
country_code |
default |
location |
an |
search_extent |
an object of class |
category |
a scalar character. Place or address type that can be used to filter suggest results. Optional. |
crs |
the CRS of the returned geometries. Passed to |
max_locations |
the maximum number of results to return. The default is 15 with a maximum of 50. Optional. |
for_storage |
default |
match_out_of_range |
set to |
location_type |
default |
lang_code |
default |
source_country |
default |
preferred_label_values |
default NULL. Must be one of |
batch_size |
the number of addresses to geocode per
request. Uses the suggested batch size property of the
|
geocoder |
default |
token |
an object of class |
.progress |
default |
Addresses are partitioned into batches of up to batch_size
elements. The batches are then sent to the geocoding service
in parallel using httr2::req_perform_parallel()
.
The JSON responses are then processed
using Rust and returned as an sf object.
Utilizes the /geocodeAddresses
endpoint.
an sf
object
# Example dataset from the Urban Institute ## Not run: fp <- paste0( "https://urban-data-catalog.s3.amazonaws.com/", "drupal-root-live/2020/02/25/geocoding_test_data.csv" ) to_geocode <- read.csv(fp) geocode_addresses( address = to_geocode$address, city = to_geocode$city, region = to_geocode$state, postal = to_geocode$zip ) ## End(Not run)
# Example dataset from the Urban Institute ## Not run: fp <- paste0( "https://urban-data-catalog.s3.amazonaws.com/", "drupal-root-live/2020/02/25/geocoding_test_data.csv" ) to_geocode <- read.csv(fp) geocode_addresses( address = to_geocode$address, city = to_geocode$city, region = to_geocode$state, postal = to_geocode$zip ) ## End(Not run)
Create an object of class GeocodeServer
from a URL. This object
stores the service definition of the geocoding service as a list object.
geocode_server(url, token = arc_token())
geocode_server(url, token = arc_token())
url |
the URL of a geocoding server. |
token |
an object of class |
an object of class GeocodeServer
.
server_url <- "https://geocode.arcgis.com/arcgis/rest/services/World/GeocodeServer" geocode_server(server_url)
server_url <- "https://geocode.arcgis.com/arcgis/rest/services/World/GeocodeServer" geocode_server(server_url)
Create a data.frame of ISO 3166 2 and 3 digit Country codes.
iso_3166_codes()
iso_3166_codes()
Country codes provided by rust_iso3166
.
a data.frame
with columns country
, code_2
, code_3
.
head(iso_3166_codes())
head(iso_3166_codes())
Evaluates the logged in user from an authorization token and returns a data.frame containing the available geocoding services for the associated token.
For users who have not signed into a private portal or ArcGIS Online, the public ArcGIS World Geocoder is used. Otherwise, the first available geocoding service associated with your authorization token is used.
list_geocoders(token = arc_token()) default_geocoder(token = arc_token())
list_geocoders(token = arc_token()) default_geocoder(token = arc_token())
token |
an object of class |
The default_geocoder()
will return the ArcGIS World Geocoder if no
token is available. list_geocoder()
requires an authorization
token.
To manually create a GeocodeServer
object, see geocode_server()
.
a data.frame
with columns url
, northLat
, southLat
,
eastLon
, westLon
, name
, suggest
, zoomScale
, placefinding
, batch
.
# Default geocoder object # ArcGIS World Geocoder b/c no token default_geocoder() # Requires an Authorization Token ## Not run: list_geocoders() ## End(Not run)
# Default geocoder object # ArcGIS World Geocoder b/c no token default_geocoder() # Requires an Authorization Token ## Not run: list_geocoders() ## End(Not run)
Determines the address for a given point.
reverse_geocode( locations, crs = sf::st_crs(locations), ..., lang_code = NULL, feature_type = NULL, location_type = c("rooftop", "street"), preferred_label_values = c("postalCity", "localCity"), for_storage = FALSE, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
reverse_geocode( locations, crs = sf::st_crs(locations), ..., lang_code = NULL, feature_type = NULL, location_type = c("rooftop", "street"), preferred_label_values = c("postalCity", "localCity"), for_storage = FALSE, geocoder = default_geocoder(), token = arc_token(), .progress = TRUE )
locations |
an |
crs |
the CRS of the returned geometries. Passed to |
... |
unused. |
lang_code |
default |
feature_type |
limits the possible match types returned. Must be one of
|
location_type |
default |
preferred_label_values |
default NULL. Must be one of |
for_storage |
default |
geocoder |
default |
token |
an object of class |
.progress |
default |
This function utilizes the
/reverseGeocode
endpoint of a geocoding service. By default, it uses
the public ArcGIS World Geocoder.
Intersection matches are only returned when feature_types = "StreetInt"
. See REST documentation for more.
Specifies whether the output geometry shuold be the rooftop point or the street entrance location.
The location_type
parameter changes the geometry's placement but does not
change the attribute values of X
, Y
, or DisplayX
, and DisplayY
.
Very Important
The argument for_storage
is used to determine if the request allows you to
persist the results of the query. It is important to note that there are
contractual obligations to appropriately set this argument. You cannot save
or persist results when for_storage = FALSE
(the default).
The /reverseGeocode
endpoint can only handle one address at a time. To
make the operation as performant as possible, requests are sent in parallel
using httr2::req_perform_parallel()
. The JSON responses are then processed
using Rust and returned as an sf object.
An sf object.
# Find addresses from locations reverse_geocode(c(-117.172, 34.052))
# Find addresses from locations reverse_geocode(c(-117.172, 34.052))
The results of geocoding operations cannot be stored or
persisted unless the for_storage
argument is set to
TRUE
. The default argument value is for_storage = FALSE
, which indicates the results of the operation can't be stored, but they can be temporarily displayed on a map, for instance. If you store the results, in a database, for example, you need to set this parameter to true.
See the official documentation for more context.
This function returns candidate locations based on a partial search query. It is designed to be used in an interactive search experience in a client facing application.
suggest_places( text, location = NULL, category = NULL, search_extent = NULL, max_suggestions = NULL, country_code = NULL, preferred_label_values = NULL, geocoder = default_geocoder(), token = arc_token() )
suggest_places( text, location = NULL, category = NULL, search_extent = NULL, max_suggestions = NULL, country_code = NULL, preferred_label_values = NULL, geocoder = default_geocoder(), token = arc_token() )
text |
a scalar character of search key to generate a place suggestion. |
location |
an |
category |
a scalar character. Place or address type that can be used to filter suggest results. Optional. |
search_extent |
an object of class |
max_suggestions |
default |
country_code |
default |
preferred_label_values |
default NULL. Must be one of |
geocoder |
default |
token |
an object of class |
Unlike the other functions in this package, suggest_places()
is not
vectorized as it is intended to provide search suggestions for individual
queries such as those made in a search bar.
Utilizes the /suggest
endpoint.
A data.frame
with 3 columns: text
, magic_key
, and is_collection
.
# identify a search point location <- sf::st_sfc(sf::st_point(c(-84.34, 33.74)), crs = 4326) # create a search extent from it search_extent <- sf::st_bbox(sf::st_buffer(location, 10)) # find suggestions from it suggestions <- suggest_places( "bellwood", location, search_extent = search_extent ) # get address candidate information # using the text and the magic key find_address_candidates( suggestions$text, magic_key = suggestions$magic_key )
# identify a search point location <- sf::st_sfc(sf::st_point(c(-84.34, 33.74)), crs = 4326) # create a search extent from it search_extent <- sf::st_bbox(sf::st_buffer(location, 10)) # find suggestions from it suggestions <- suggest_places( "bellwood", location, search_extent = search_extent ) # get address candidate information # using the text and the magic key find_address_candidates( suggestions$text, magic_key = suggestions$magic_key )
The ArcGIS World Geocoder
is made publicly available for some uses. The world_geocoder
object is used
as the default GeocodeServer
object in default_geocoder()
when no
authorization token is found. The find_address_candidates()
,
reverse_geocode()
, and suggest_places()
can be used without an
authorization token. The geocode_addresses()
funciton requires an
authorization token to be used for batch geocoding.
world_geocoder
world_geocoder
An object of class GeocodeServer
(inherits from list
) of length 12.
an object of class GeocodeServer