MyNixOS website logo
Description

Call the 'NaPTAN' API Through R.

An R wrapper for pulling data from the National Public Transport Access Nodes ('NaPTAN') API (<https://www.api.gov.uk/dft/national-public-transport-access-nodes-naptan-api/#national-public-transport-access-nodes-naptan-api>). This allows users to download 'NaPTAN' transport information, for the full dataset, by ATCO region code, or by name of region.

naptanr

Lifecycle:experimental CRANstatus R-CMD-check

The goal of naptanr is to allow easy interface between the National Public Transport Access Nodes (NaPTAN) API and R. The NaPTAN dataset provides the location and type of every location you can join or leave public transport in England, Scotland and Wales. Further details and documentation on the NaPTAN API can be found here.

Installation

You can install the development version of naptanr from GitHub with:

# install.packages("devtools")
devtools::install_github("department-for-transport-public/naptanr")

Usage

naptanr has several functions designed to make it easy for you to interrogate the NaPTAN API and receive the results as an R dataframe object.

Returning Naptan results from ATCO codes

The call_naptan() function allows you to request data for one or more ATCO area codes.

Calling this function with no arguments returns a full data frame of all results currently stored in Naptan.

You can also specify the area you would like to see results for by using the atco argument in this function. You can give a single three-digit ATCO code as a string, or multiple ATCO codes as a vector of strings, e.g.

library(naptanr)

## Single ATCO code
call_naptanr(atco = "050")

## Multiple ATCO codes
call_naptanr(atco = c("050", "290"))

If you provide one or more invalid ATCO codes, the function will return an error and let you know which ATCO codes are incorrect.

Returning NaPTAN results from region name

Functions are also available to help you if you don't know the ATCO code of the region(s) you're interested in. The lookup_atco_codes() function returns a lookup table of area names and ATCO Area Codes. Calling this function without arguments returns a full list of all available ATCO area codes.

If you'd like to filter this list down, the function offers several arguments to do this. You can use the area_name argument to specify the full or partial name of the area you're interested in, for example:

library(naptanr)

## Returns area code for Cornwall only
lookup_atco_codes(area_name = "cornwall")

## Returns area code for all areas containing the partial string "west"
lookup_atco_codes(area_name = "west")

This search operates via regular expression and is not case sensitive.

You can also return the area codes for a single country using the country argument. Specify "ENG", "SCO" or "WAL" to return values for England, Scotland or Wales respectively.

library(naptanr)

## Returns area codes for all areas in Wales 
lookup_atco_codes(country = "WAL")

You can also use the same type of lookup to return NaPTAN data directly using the call_naptan_region() function. Passing a full or partial area name to the region_string argument returns results for all areas which match this lookup.

library(naptanr)

## Returns results for all areas containing the string "yorkshire"  
call_naptan_region(region_string = "yorkshire")

Metadata

Version

1.0.1

License

Unknown

Platforms (77)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-freebsd
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64-windows
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows