knitr::opts_chunk$set(collapse = TRUE, comment = "#>")
There are several other R packages interacting with the ODK ecosystem, and/or OData.
| Package | ruODK
| odkr
| odk
| odkmeta
| koboloadeR
| Pentaho Kettle tutorial
|------------------------------|---------------|---------------|---------------|---------------|---------------|---------------|
| Elevator pitch | "ckanr for ODK Central" | "Drive ODK Briefcase through R" | "Export ODK Aggregate to SPSS" | "Export ODK Aggregate to STATA" | "Metapackage for the extended ODK ecosystem" | "What ruODK does, but as GUI" |
| Last commit | | | Nov 2017 | | | |
| Website | | | | | | |
| Test coverage | | | ❌ | In repo | | NA |
| Working examples | README, 3 vignettes, pkgdown, Rmd templates | README, pkgdown | CRAN PDF | README | README, 9 vignettes, shiny apps, pkgdown | Tutorial with screenshots |
| Available on CRAN | | | | NA | NA | NA |
| Technologies | Tidyverse R, XForms | Base R | Base R | Stata | R metapackage, XlsForms | Pentaho Kettle GUI |
| External dependencies | None | Java, ODK Briefcase | SPSS | Stata | Java, ODK Briefcase, wraps odkr
| Pentaho Kettle, Java |
| Affiliation | ROpenSci | RapidSurveys | Muntashir-Al-Arefin | ODK Central developer Matt White | UNHCR | Schemetrica |
| Covers ODK Central OData API | ✅ | ❌ | ❌ | ❌ | ❌ | ✅ |
| Covers ODK Central REST API | ✅ | ❌ | ❌ | ❌ | ❌ | ❌ |
| Covers ODK Central bulk export | ✅ | ❌ | ❌ | ✅ | ❌ | ✅ |
| Covers ODK Central OpenRosa API | ❌ no need, gets all data through OData/REST API | ✅ via ODK Briefcase | ❌ | ❌ | ✅ via ODK Briefcase | ✅ |
| Data post-processing | ✅ | ✅ | ❌ | ✅ | ✅ | ✅ |
| Data visualisation examples | ✅ | ❌ | ❌ | ❌ | ✅ | ❌ |
In summary:
ruODK
provides a dependency-free interface to ODK Central.
koboloadeR
is a metapackage containing lots of ancillary packages, with some
heavy dependencies on Java and ODK Briefcase (which in turn can access ODK Central).
Although built around the XlsForm standard and paradigm, koboloadeR
is well worth
exploring as a larger context to data wrangling in the ODK ecosystem.
Schemetrica's tutorial illustrates data ETL from ODK Central and deserves a special
mention, as it is both very recent and aimed specifically against ODK Central.
The GUI paradigm of Pentaho Kettle addresses a different audience to the scripting
paradigm of ruODK
. It should be mentioned that Kettle's composable data
manipulation steps can be used for many other use cases apart from ODK Central.
| Package | ruODK
| odataR
| cbsodataR
| OData
| OData JDBC R tutorial
|------------------------------|---------------|---------------|---------------|---------------|--------------|
| Elevator pitch | "ckanr for ODK Central" | "OData client for https://opendata.cbs.nl (and similar)" | "OData client for https://www.cbs.nl" | "Minimal OData example" | "Minimal RJDBC example" |
| Last commit | | | | Dec 2016 | ❓ |
| Website | | | | | |
| Test coverage | | ❌ | | ❌ | ❌ |
| Targets ODK Central | ✅ | ❌ | ❌ | ❌ | ❌ |
| Works with ODK Central | ✅ | ❓ | ❓ | ❌ | ❌ |
| Data wrangling helpers for post-processing | ✅ | some | some | ❌ | ❌ |
| Actively maintained to work against ODK Central | ✅ | ❌ | ❌ | ❌ | ❌ |
| Technologies | R, httr, xml2, tidyr, purrr | R, jsonlite, tidyverse | R, tidyverse | R, XML, RJSONIO | R, RJDBC, Java |
| External dependencies | ✅ None | ✅ None | ✅ None | ✅ None | ❌ JDBC, Java |
| Available on CRAN | | NA | | | NA |
In summary:
ruODK
is the only R package explicitly aimed at ODK Central's OData and
RESTful API, as well as providing context and helpers around specific recurring
data wrangling tasks.
The value of OData lies in its self-descriptive nature, which allows tools to
introspect the data structures and types. Both GUI-driven tools like MS PowerBI
and ruODK
use this introspection to assist users in wrangling their own data.
The script-based approach of ruODK
allows to automate the data extraction,
transformation, and reporting pipeline, and therefore provide reproducible
reporting.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.