R interface to the Data Retriever.
The Data Retriever automates the tasks of finding, downloading, and cleaning up publicly available data, and then stores them in a local database or csv files. This lets data analysts spend less time cleaning up and managing data, and more time analyzing it.
This package lets you access the Retriever using R, so that the Retriever's data handling can easily be integrated into R workflows.
rdataretriever
is an R wrapper for the Python based Data Retriever. This means
that Python and the retriever
package need to be installed first.
Use this if you are new to Python or don't have a local Python installation
- Install the Python 3.7 version of the miniconda Python distribution from https://docs.conda.io/en/latest/miniconda.html
- In R install the
reticulate
package (the current release, 1.13, does not work on Windows so installation using devtools is recommended):
devtools::install_github("rstudio/reticulate")
- In R run the following to install the
retriever
Python package:
library(reticulate)
py_available(initialize = TRUE)
py_install("retriever")
- Install the
rdataretriever
R package:
install.packages("rdataretriever") # from CRAN
devtools::install_github("ropensci/rdataretriever") # from GitHub
Use this if you are already familiar with Python and have a local Python installation
- Check that your local Python installation is Python 3.6 and above
- In R install the
reticulate
package:
install.packages("reticulate")
- In R run the following (
replacing "/path/to/python" with the path to you Python executeable
) to install theretriever
Python package:
library(reticulate)
use_python("/path/to/python")
py_install("retriever")
- Install the
rdataretriever
R package:
devtools::install_github("ropensci/rdataretriever") # from GitHub
install.packages("rdataretriever") # from CRAN
library(rdataretriever)
# List the datasets available via the Retriever
rdataretriever::datasets()
# Install the portal into csv files in your working directory
rdataretriever::install_csv('portal')
# Download the raw portal dataset files without any processing to the
# subdirectory named data
rdataretriever::download('portal', './data/')
# Install and load a dataset as a list
portal = rdataretriever::fetch('portal')
names(portal)
head(portal$species)
Set-up and Requirements
Tools
- PostgreSQL with PostGis, psql(client), raster2pgsql, shp2pgsql, gdal,
The rdataretriever
supports installation of spatial data into Postgres DBMS
.
-
Install PostgreSQL and PostGis
To install
PostgreSQL
withPostGis
for use with spatial data please refer to the OSGeo Postgres installation instructions.We recommend storing your PostgreSQL login information in a
.pgpass
file to avoid supplying the password every time. See the.pgpass
documentation for more details.After installation, Make sure you have the paths to these tools added to your system's
PATHS
. Please consult an operating system expert for help on how to change or add thePATH
variables.For example, this could be a sample of paths exported on Mac:
#~/.bash_profile file, Postgres PATHS and tools. export PATH="/Applications/Postgres.app/Contents/MacOS/bin:${PATH}" export PATH="$PATH:/Applications/Postgres.app/Contents/Versions/10/bin"
-
Enable PostGIS extensions
If you have
Postgres
set up, enablePostGIS
extensions. This is done by using eitherPostgres CLI
orGUI(PgAdmin)
and runFor psql CLI
psql -d yourdatabase -c "CREATE EXTENSION postgis;" psql -d yourdatabase -c "CREATE EXTENSION postgis_topology;"
For GUI(PgAdmin)
CREATE EXTENSION postgis; CREATE EXTENSION postgis_topology
For more details refer to the PostGIS docs.
Sample commands
rdataretriever::install_postgres('harvard-forest') # Vector data
rdataretriever::install_postgres('bioclim') # Raster data
# Install only the data of USGS elevation in the given extent
rdataretriever::install_postgres('usgs-elevation', list(-94.98704597353938, 39.027001800158615, -94.3599408119917, 40.69577051867074))
To run the image interactively
docker-compose run --service-ports rdata /bin/bash
To run tests
docker-compose run rdata Rscript load_and_test.R
Make sure you have tests passing on R-oldrelease, current R-release and R-devel
To check the package
R CMD Build #build the package
R CMD check --as-cran --no-manual rdataretriever_[version]tar.gz
To Test
setwd("./rdataretriever") # Set working directory
# install all deps
# install.packages("reticulate")
library(DBI)
library(RPostgreSQL)
library(RSQLite)
library(reticulate)
library(RMariaDB)
install.packages(".", repos = NULL, type="source")
roxygen2::roxygenise()
devtools::test()
To get citation information for the rdataretriever
in R use citation(package = 'rdataretriever')
A big thanks to Ben Morris for helping to develop the Data Retriever. Thanks to the rOpenSci team with special thanks to Gavin Simpson, Scott Chamberlain, and Karthik Ram who gave helpful advice and fostered the development of this R package. Development of this software was funded by the National Science Foundation as part of a CAREER award to Ethan White.