Extending climaemet

climaemet provides several functions for accessing a selection of endpoints of the AEMET API tool. However, this package does not cover in full all the capabilities of the API.

For that reason, we provide the get_data_aemet() function, that allows to access any API endpoint freely. The drawback is that the user would need to handle the results by him/herself.

library(climaemet)

Example: Normalized text

Some API endpoints, as predicciones-normalizadas-texto, provides the results as plain text on natural language. These results are not parsed by climaemet, but can be retrieved as this:

# endpoint, today forecast

today <- "/api/prediccion/nacional/hoy"

# Metadata
knitr::kable(get_metadata_aemet(today))
unidad_generadora descripcion periodicidad formato copyright notaLegal
Grupo Funcional de Predicción de Referencia Predicción general nacional para hoy / mañana / pasado mañana / medio plazo (tercer y cuarto día) / tendencia (del quinto al noveno día) Disponibilidad. Para hoy, solo se confecciona si hay cambios significativos. Para mañana y pasado mañana diaria a las 15:00 h.o.p.. Para el medio plazo diaria a las 16:00 h.o.p.. La tendencia, diaria a las 18:30 h.o.p. ascii/txt © AEMET. Autorizado el uso de la información y su reproducción citando a AEMET como autora de la misma. https://www.aemet.es/es/nota_legal

# Data
pred_today <- get_data_aemet(today)
#> 
#> Results are MIME type: text/plain
#> Returning data as string
# Produce a result

clean <- gsub("\r", "\n", pred_today, fixed = TRUE)
clean <- gsub("\n\n\n", "\n", clean, fixed = TRUE)

cat(paste("---\n\n", clean, "\n---"))

AGENCIA ESTATAL DE METEOROLOGÍA PREDICCIÓN GENERAL PARA ESPAÑA DÍA 06 DE DICIEMBRE DE 2024 A LAS 08:21 HORA OFICIAL PREDICCIÓN VÁLIDA PARA EL VIERNES 6

A.- FENÓMENOS SIGNIFICATIVOS Nieblas matinales con probabilidad de ser más densas y persistentes en zonas de Extremadura y en la meseta norte. Intervalos fuertes de viento de componente oeste con rachas muy fuertes en el Cantábrico, Ampurdán, Pirineo y entorno del bajo Ebro. Ascensos notables de las temperaturas en áreas del nordeste peninsular.

B.- PREDICCIÓN Se prevé que para este día se mantenga una situación anticiclónica en la Península y Baleares con predominio de cielos poco nubosos o con intervalos de nubes altas. Asimismo, se prevé abundante nubosidad baja matinal en amplias zonas de la mitad norte peninsular y suroeste, con probables nieblas matinales que no se descartan densas y persistentes en zonas bajas de Extremadura y en la meseta Norte. Únicamente el extremo norte peninsular seguirá bajo la influencia de la circulación atlántica, con el paso de frentes aportando abundante nubosidad y dejando precipitaciones débiles en Galicia, Cantábrico y Pirineos, sin descartarlas en aledaños al sur y siendo más abundantes en cara norte del Pirineo y el Cantábrico oriental. No se esperan tampoco precipitaciones en Canarias, con intervalos de nubes bajas en los nortes de las islas de mayor relieve y cielos poco nubosos o con intervalos de nubes altas en el resto.

Las temperaturas máximas aumentarán en la mitad sureste peninsular y Baleares, notablemente en zonas de Cataluña, y en general con pocos cambios en el resto. Las mínimas también ascenderán, notablemente en zonas del nordeste, y con pocos cambios en el cuadrante suroeste. Con ello las heladas quedan restringidas a cotas altas de los Pirineos.

Predominarán los vientos de componente oeste en la Península y Baleares, en general flojos en el interior, y más intensos en litorales y nordeste, con probables intervalos de fuerte y/o rachas muy fuertes en el Cantábrico, Pirineos, Ampurdán y bajo Ebro. En Canarias soplará un alisio moderado con algún intervalo de fuerte en canales.


Example: Maps

AEMET also provides map data, usually on image/gif format. One way to get this kind of data is as follows:

# Endpoint of a map
a_map <- "/api/mapasygraficos/analisis"

# Metadata
knitr::kable(get_metadata_aemet(a_map))
unidad_generadora descripción periodicidad formato copyright notaLegal
Grupo Funcional de Jefes de Turno Mapas de análisis de frentes en superficie Dos veces al día, a las 02:00 y 14:00 h.o.p. en invierno y a las 03:00 y 15:00 en verano. image/gif © AEMET. Autorizado el uso de la información y su reproducción citando a AEMET como autora de la misma. https://www.aemet.es/es/nota_legal

the_map <- get_data_aemet(a_map)
#> 
#> Results are MIME type: image/gif
#> Returning raw data


# Write as gif and include it
giffile <- "example-gif.gif"
writeBin(the_map, giffile)

# Display on the vignette
knitr::include_graphics(giffile)
Example: Surface analysis map provided by AEMET

Example: Surface analysis map provided by AEMET