This is an R interface to weather underground’s API.
In order to use this library please register
for an API key. The free-tier should be sufficient if you aren’t calling
the API more than a 500 times per day. Please note that the free tier
also limits requests to 10 per minute. If you are grabbing weather for a
large date range using history_range then by default
limit = 10 will limit the calls to a maximum of 10 per
minute. This package has functions that follow the online
api.
This package is officially on CRAN; install using
install.packages("rwunderground").
To install the latest version please use devtools. If
you don’t have devtools install using
install.packages("devtools"). Afterwards install
rwunderground using devtools:
devtools::install_github("ALShum/rwunderground").
Once you have your API key as indicated above you can set the key in
R using: rwunderground::set_api_key("YOUR KEY"). You only
have to do this once per R session. Alternatively you can save the key
in your local .Renviron file by adding the line
WUNDERGROUNDID = 'your key here'.
For any of the API functions you must first specify a location – the
first argument of all the API functions is a location. Locations can be
specified by the airport code, zip code, personal weather station ID or
simply by specifying state and city (if in US) or country and city (if
outside US). The set_location function will validate
locations and format things correctly or you can use a (correctly
formatted) string.
Setting the location to Honolulu, HI:
set_location(territory = "Hawaii", city = "Honolulu").
Setting the location to Mombasa, Kenya:
set_location(territory = "Kenya", city = "Mombasa").
Setting the location to San Diego, California:
set_location(territory = "California", city = "San Diego")
As alluded above, set_location will attempt to validate
and make sure the locations are formatted correctly. If you have trust
in your own geography and spelling skills then you can simple replace
the set_location function with a string formatted as
"territory/city" such as: "Hawaii/Honolulu" or
"Kenya/Mombasa".
Locations can be specified by airport codes.
Setting the location to Seattle/Tacoma airport:
set_location(airport_code = "SEA")
If you don’t know the airport code you can look them up using
lookup_airport: lookup_airport("seattle").
This will lookup IATA and ICAO airport codes.
set_location(zip_code = "96813")
set_location(lat_long = "50,-100") Note that coordinates
should be comma separated.
If no argument is provided to set_location then by default the nearest weather station will be used. You can also specify location based on lat/lon or personal weather station ID.
Note: by default units are in imperial (temperature is F, windspeed
in MPH etc.) – sorry rest of the world! To use metric, you can set
use_metric = TRUE for many of the functions.
history, history_daily,
history_range: weather history functionsforecast3day, forecast10day: daily summary
forecastshourly, hourly10day: hourly forecastsplanner: Historical weather summary for date rangealerts: Weather alertsalmanac: historical weather records for current
dateastronomy: sunrise/sunset and moonrise/moonsetconditions: current weather conditionsgeolookup: weather station lookupcurrent_hurricane: current hurricane informationsatellite: satellite image URLstide, rawtide: tide forecastswebcam: live webcam image URLSyesterday: historical weather information for
yesterdaylookup_airport: Look up airport codes if you plan on
looking up weather data using airport locations.After a location is set, weather history is available using
history.
To request the weather for Honolulu, HI on January 31, 2015:
history(set_location(territory = "Hawaii", city = "Honolulu"), date = 20150131)
Note that dates must be in YYYYMMDD.
Forecast weather data is available using forecast3day
and forecast10day. Hourly forecasts are also available
using hourly and hourly10day. The forecast
functions do a daily summary forecast and the hourly functions do hourly
forecasts.
To get the 10 day forecast and 10 day hourly forecast for Honolulu, Hawaii:
forecast10day(set_location(territory = "Hawaii", city = "Honolulu"))
hourly10day(set_location(territory = "Hawaii", city = "Honolulu"))
Note that dates for this must be in MMDD form:
planner(set_location(territory = "IR", city = "Tehran"), start_date = "0101", end_date = "0131")
Tide high/low forecasts are available using tide and
hourly tide forecasts available using rawtide.
To get the high/low tide information for Honolulu, Hawaii:
tide(set_location(territory = "Hawaii", city = "Honolulu"))
rawtide(set_location(territory = "Hawaii", city = "Honolulu"))
Weather alerts are available as plain text.
Weather Alerts for Honolulu, Hawaii:
alerts(set_location(territory = "Hawaii", city = "Honolulu"))