inst/doc/pxweb.R

## ----basecode, message=FALSE, eval=FALSE, echo=FALSE--------------------------
#  # Below are code to run to setup the data
#  
#  # Get PXWEB levels
#  px_levels <- pxweb_get("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/")
#  px_levels
#  save(px_levels, file = "vignettes/px_levels_example.rda")
#  
#  # Get PXWEB metadata about a table
#  px_meta <- pxweb_get("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy")
#  px_meta
#  save(px_meta, file = "vignettes/px_meta_example.rda")
#  
#  
#  # Example Download
#  pxweb_query_list <-
#    list(
#      "Civilstand" = c("*"), # Use "*" to select all
#      "Kon" = c("1", "2"),
#      "ContentsCode" = c("BE0101N1"),
#      "Tid" = c("2015", "2016", "2017")
#    )
#  pxq <- pxweb_query(pxweb_query_list)
#  
#  pxd <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  save(pxd, file = "vignettes/pxd_example.rda")
#  
#  pxq$response$format <- "json-stat"
#  pxjstat <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  save(pxjstat, file = "vignettes/pxjstat_example.rda")
#  
#  pxq$response$format <- "px"
#  pxfp <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  save(pxfp, file = "vignettes/pxfp_example.rda")
#  
#  pxweb_cite_example <- capture.output(pxweb_cite(pxd))
#  

## ----install1, eval=FALSE-----------------------------------------------------
#  install.packages("pxweb")

## ----install2, eval=FALSE-----------------------------------------------------
#  library("remotes")
#  remotes::install_github("ropengov/pxweb")

## ----test, message=FALSE, warning=FALSE, eval=TRUE----------------------------
library(pxweb)

## ----locale, eval=FALSE-------------------------------------------------------
#  Sys.setlocale(locale = "UTF-8")

## ----standardquery, message=FALSE, eval=FALSE---------------------------------
#  # Navigate through all pxweb api:s in the R package API catalogue
#  d <- pxweb_interactive()
#  
#  # Get data from SCB (Statistics Sweden)
#  d <- pxweb_interactive("api.scb.se")
#  
#  # Fetching data from statfi (Statistics Finland)
#  d <- pxweb_interactive("pxnet2.stat.fi")
#  
#  # Fetching data from StatBank (Statistics Norway)
#  d <- pxweb_interactive("data.ssb.no")
#  
#  # To see all available PXWEB APIs use
#  pxweb_apis <- pxweb_api_catalogue()

## ----inapi, message=FALSE, eval=FALSE-----------------------------------------
#  # Start with a specific path.
#  d <- pxweb_interactive("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A")

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  file.edit(pxweb_api_catalogue_path())

## ----levels, message=FALSE, eval=FALSE----------------------------------------
#  # Get PXWEB levels
#  px_levels <- pxweb_get("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/")
#  px_levels

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("px_levels_example.rda")
px_levels

## ----meta, message=FALSE, eval=FALSE------------------------------------------
#  # Get PXWEB metadata about a table
#  px_meta <- pxweb_get("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy")
#  px_meta

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("px_meta_example.rda")
px_meta

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  d <- pxweb_interactive("https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy")

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
# save(d, file = "d_example.rda")
load("d_example.rda")

## ---- message=FALSE, eval=TRUE------------------------------------------------
d$url
d$query

## ----interactive_query, message=FALSE, eval=TRUE------------------------------
pxweb_query_as_json(d$query, pretty = TRUE)

## ----pxq, message=FALSE, eval=FALSE-------------------------------------------
#  pxq <- pxweb_query("path/to/the/json/query.json")

## ----rquery, message=FALSE, eval=TRUE-----------------------------------------
pxweb_query_list <-
  list(
    "Civilstand" = c("*"), # Use "*" to select all
    "Kon" = c("1", "2"),
    "ContentsCode" = c("BE0101N1"),
    "Tid" = c("2015", "2016", "2017")
  )
pxq <- pxweb_query(pxweb_query_list)
pxq

## ----validate_query, message=FALSE, eval=TRUE---------------------------------
pxweb_validate_query_with_metadata(pxq, px_meta)

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  pxd <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  pxd

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("pxd_example.rda")
pxd

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  pxq$response$format <- "json-stat"
#  pxjstat <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  pxjstat

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("pxjstat_example.rda")
pxjstat

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  pxq$response$format <- "px"
#  pxfp <- pxweb_get(
#    "https://api.scb.se/OV0104/v1/doris/en/ssd/BE/BE0101/BE0101A/BefolkningNy",
#    pxq
#  )
#  pxfp

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("pxfp_example.rda")
pxfp

## ---- message=FALSE, eval=TRUE------------------------------------------------
pxdf <- as.data.frame(pxd, column.name.type = "text", variable.value.type = "text")
head(pxdf)

## ---- message=FALSE, eval=TRUE------------------------------------------------
pxdf <- as.data.frame(pxd, column.name.type = "code", variable.value.type = "code")
head(pxdf)

## ---- message=FALSE, eval=TRUE------------------------------------------------
pxmat <- as.matrix(pxd, column.name.type = "code", variable.value.type = "code")
head(pxmat)

## ---- message=FALSE, eval=TRUE------------------------------------------------
pxdc <- pxweb_data_comments(pxd)
pxdc

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  as.data.frame(pxdc)

## ---- message=FALSE, eval=FALSE-----------------------------------------------
#  pxweb_cite(pxd)

## ---- message=FALSE, eval=TRUE, echo=FALSE------------------------------------
load("pxweb_cite_example.rda")
cat(pxweb_cite_example, sep = "\n")

## ----sessioninfo, message=FALSE, warning=FALSE--------------------------------
sessionInfo()

Try the pxweb package in your browser

Any scripts or data that you put into this service are public.

pxweb documentation built on May 29, 2024, 2:28 a.m.