The package introduces several functions that identify special columns in country data. These functions can be used to automate basic tasks and detect data formats. Here is an overview of a few functionalities.
In this vignette we will use a dataset of country policies as an example for the functions in the package. This dataset contains 41 columns and has a rather complex structure. Every row is identified by a combination of Country name (column 21), Year (Column 9), Policy measure number (column 1), and HS code (column 39) — which is a code identifying traded commodities. This dataset is an extension based on the WTO environmental databse (EDB). More information on the dataset can be found here.
#download data
temp <- tempfile()
download.file("https://fbellelli.com/data%20files/Extended%20EDB%20by%20measure-country-HS%20chapter.zip", temp, mode="wb")
#unzip and load it in R
library(data.table)
#> Warning: package 'data.table' was built under R version 4.3.1
example <- fread(
  unzip(temp,"Extended EDB by measure-country-HS chapter/Extended EDB (by measure-country-HS chapter).csv"),
  stringsAsFactors=FALSE,
  encoding = "Latin-1")The functions find_countrycol() and
find_timecol() can be used to return respectively all
columns containing country names and date/year information.
In the example below, the function find_countrycol() is
used to examine our example dataset. The argument min_share
is used to indicate whether to look for an entire column of Country
names or any column that contains Country names. This is a numeric value
indicating the minimum share of entries in the column that are country
names.
#Columns of country names
find_countrycol(example)  
#> [1] "COUNTRIES"
#Return any column containing a country name
find_countrycol(example, min_share=0) 
#> [1] "Notifying Member" "COUNTRIES"Similarly, we can look for time columns in the following way:
# Date and year columns
find_timecol(example)  
#> [1] "Year"By default, the function will return the name of the column. However,
the argument return_index can be used to get the indices of
the column in the table.
find_countrycol(example, return_index = TRUE)
#> [1] 21
find_timecol(example, return_index = TRUE)  
#> [1] 9Computations may take long on large tables with many columns. To
speed up operations, these functions operate by evaluating the table on
a random sample of rows. The sample size can be adjusted with the
argument sample_size. It also possible to request to use
the entire table by passing the value NA. Finally, it is
also possible to request not to return columns containing
NA values by specifying: allow_NA = FALSE.
These two functions are based on is_country() and
is_date(), which can be used to test if a string is a
Country name and a date. An overview of the first function is provided
in the vignette Dealing
with country names, here we have a look at `is_date()´.
is_date() takes a string vector as argument and outputs
a boolean vector indicating whether the strings are dates. The argument
formats can be used to specify the formats to be checked.
Standard R notation can be used for date elements (see the table
below).
test <- c("December 2022", "20/01/1970", "Banana", "12.13.2000") 
is_date(test)
#> [1]  TRUE  TRUE FALSE  TRUE
is_date(test, formats=c("%d/%m/%Y"))
#> [1] FALSE  TRUE FALSE FALSE| Symbol | Definition | Example | 
|---|---|---|
| %d | Day number | 13 | 
| %a | Abbreviated day name | Mon | 
| %A | Full day name | Monday | 
| %m | Month number | 2 | 
| %b | Abbreviated month name | Feb | 
| %B | Full month name | February | 
| %y | Year 2-digits | 22 | 
| %Y | Year 4-digits | 2022 | 
find_keycol() is a function that can be used to automate
the search of key columns in datasets. A table key is a column or set of
columns that uniquely identifies the entries in the table. This function
was specifically designed for country data, so it will prioritise the
search of country and time columns, which are often keys in country
data.
As shown below, the function correctly identifies the keys for the complex dataset introduced at the beginning of this article.
find_keycol(example, allow_NA = TRUE)
#>                       country                          time 
#>                   "COUNTRIES"                        "Year" 
#>                         other                         other 
#>                          "Nr" "Tentative HS chapters match"The function outputs a vector of column names that uniquely
identifies the entries in the table. In addition, it also indicates
whether the column contains country, time or
other information. Just like the other find function
in this page, it is possible to request the column index instead of the
name by passing return_index = TRUE.
Due to the potentially very high number of column combinations in a
table, the function only tests the more likely options. The function
will first look for country and time columns. Next, left-most columns
are prioritised. Also, the function will only look for the most common
country data formats (e.g. cross-sectional, time-series, panel data,
dyadic, etc.) and only searches for up to two additional key columns of
type other. If no key is found at the end of the search,
the function returns a NULL value.
Computation can be slow on large datasets. Therefore, the function
evaluates only a random sample of rows from the table. The sample size
can be controlled with sample_size. Moreover, it is also
possible to restrict the search to a subset of columns by providing a
vector of column names or indices in the argument
search_only.
#This will only check if a key is found among the first three columns
find_keycol(example, allow_NA = TRUE, search_only = 1:3)
#> NULLFinally, the function also permits the user to specify whether
columns containing NA values are allowed to be considered
as table keys. The default is allow_NA = FALSE because keys
should typically not contain missing values. However, in our example
dataset the column Tentative.HS.chapters.match contains
blank entries which are read in R as NA, therefore the
default would return NULL. The argument
allow_NA is present to deal with these edge cases.
find_keycol(example, allow_NA = FALSE)
#> NULLIf the user wants to test a specific set of columns, the package also
provides the function is_keycol() to check whether the
provided columns uniquely identify the entries in the dataset.
is_keycol(example, c("COUNTRIES","Year"), allow_NA = TRUE)
#> [1] FALSE
is_keycol(example, c("COUNTRIES","Year", "Nr","Tentative HS chapters match"), allow_NA = TRUE)
#> 
#> Found NA values in: Tentative HS chapters match
#> [1] TRUE