Title: | Fast, Flexible, and User-Friendly Record Linkage Methods |
---|---|
Description: | Provides a flexible set of tools for matching two un-linked data sets. 'fedmatch' allows for three ways to match data: exact matches, fuzzy matches, and multi-variable matches. It also allows an easy combination of these three matches via the tier matching function. |
Authors: | Melanie Friedrichs [aut], Chris Webster [aut, cre], Blake Marsh [aut], Jacob Dice [aut], Seung Lee [aut] |
Maintainer: | Chris Webster <[email protected]> |
License: | MIT + file LICENSE |
Version: | 2.0.6 |
Built: | 2024-12-17 06:34:23 UTC |
Source: | CRAN |
Data.frame with common articles
articles
articles
An object of class data.table
(inherits from data.frame
) with 23 rows and 2 columns.
clean_strings
build_clean_settings
is a convenient way to make the proper list for the
clean_settings
argument of tier_match
.
build_clean_settings( sp_char_words = fedmatch::sp_char_words, common_words = NULL, remove_char = NULL, remove_words = FALSE, stem = FALSE )
build_clean_settings( sp_char_words = fedmatch::sp_char_words, common_words = NULL, remove_char = NULL, remove_words = FALSE, stem = FALSE )
sp_char_words |
character vector. Data.frame where first column is special characters and second column is full words. The default is |
common_words |
data.frame. Data.frame where first column is abbreviations and second column is full words. |
remove_char |
character vector. string of specific characters (for example, "letters") to be removed |
remove_words |
logical. If TRUE, removes all abbreviations and replacement words in common_words |
stem |
logical. If TRUE, words are stemmed |
list with settings to pass to clean_strings
Calculate word corpus for weighted jaccard matching
build_corpus(namelist1, namelist2)
build_corpus(namelist1, namelist2)
namelist1 |
character vector of names from dataset 1 |
namelist2 |
character vector of names from dataset 2 |
a data.table with columns for frequency, inverse frequency, and log inverse frequency for each word in the two strings.
build_fuzzy_settings
is a convenient way to build the list for the fuzzy settings argument in merge_plus
build_fuzzy_settings( method = "jw", p = 0.1, maxDist = 0.05, matchNA = FALSE, nthread = getOption("sd_num_thread") )
build_fuzzy_settings( method = "jw", p = 0.1, maxDist = 0.05, matchNA = FALSE, nthread = getOption("sd_num_thread") )
method |
character vector of length 1. Either one of the methods listed in stringdist::amatch, or our custom method 'wgt_jaccard.' See the vignettes for more details. |
p |
numeric vector of length 1. See stringdist::amatch() |
maxDist |
numeric vector of length 1. See stringdist::amatch() |
matchNA |
whether or not to match on NAs, see |
nthread |
number of threads to use in the underlying C code. |
a list containing options for the 'fuzzy_settings' argument of merge_plus
.
build_multivar_settings
is a convenient way to build the list for the multivar settings argument in merge_plus
build_multivar_settings( logit = NULL, missing = FALSE, wgts = NULL, compare_type = "diff", blocks = NULL, blocks.x = NULL, blocks.y = NULL, top = 1, threshold = NULL, nthread = 1 )
build_multivar_settings( logit = NULL, missing = FALSE, wgts = NULL, compare_type = "diff", blocks = NULL, blocks.x = NULL, blocks.y = NULL, top = 1, threshold = NULL, nthread = 1 )
logit |
a glm or lm model as a result from a logit regression on a verified dataset. See details. |
missing |
boolean T/F, whether or not to treat missing (NA) observations as its own binary column for each column in by. See details. |
wgts |
rather than a lm model, you can supply weights to calculate matchscore. Can be weights from |
compare_type |
a vector with the same length as "by" that describes how to compare the variables. Options are "in", "indicator", "substr", "difference", "ratio", "stringdist", and "wgt_jaccard_dist". See the Multivar Matching Vignette for details. |
blocks |
variable present in both data sets to "block" on before computing scores. Matchscores will only be computed for observations that share a block. See details. |
blocks.x |
name of blocking variables in x. cannot supply both blocks and blocks.x |
blocks.y |
name of blocking variables in y. cannot supply both blocks and blocks.y |
top |
integer. Number of matches to return for each observation. |
threshold |
numeric. Minimum score for a match to be included in the result. |
nthread |
integer. Number of cores to use when computing all combinations. See |
a list containing options for the 'multivar_settings' argument of merge_plus
.
build_score_settings
is a convenient way to make the proper list for the
score_settings
argument of merge_plus
Each vector in build_score_settings
should be the same length, and each position (first, second, third, etc.)
corresponds to one variable to score on.
build_score_settings( score_var_x = NULL, score_var_y = NULL, score_var_both = NULL, wgts = NULL, score_type )
build_score_settings( score_var_x = NULL, score_var_y = NULL, score_var_both = NULL, wgts = NULL, score_type )
score_var_x |
character vector. the variables from the 'x' dataset to score on |
score_var_y |
character vector. the variables from the 'y' dataset to score on |
score_var_both |
the variables from both datasets (shared names) to score on, before any prefixes are applied. |
wgts |
numeric vector. The weights for the linear sum of scores |
score_type |
Charcter vector. Options are "in", "indicator", "substr", "difference", "ratio", "stringdist". See the Multivar Matching Vignette for details. |
a list containing options for the 'score_settings' argument of merge_plus
.
build_tier_settings
is a convenient way to make the proper list for the
tier_list
argument of tier_match
Each vector in build_score_settings
should be the same length, and each position (first, second, third, etc.)
corresponds to one variable to score on.
build_tier( by.x = NULL, by.y = NULL, check_merge = NULL, match_type = NULL, fuzzy_settings = build_fuzzy_settings(), score_settings = NULL, filter = NULL, filter.args = NULL, evaluate = NULL, evaluate.args = NULL, clean_settings = build_clean_settings(), clean = NULL, sequential_words = NULL, allow.cartesian = FALSE, multivar_settings = build_multivar_settings() )
build_tier( by.x = NULL, by.y = NULL, check_merge = NULL, match_type = NULL, fuzzy_settings = build_fuzzy_settings(), score_settings = NULL, filter = NULL, filter.args = NULL, evaluate = NULL, evaluate.args = NULL, clean_settings = build_clean_settings(), clean = NULL, sequential_words = NULL, allow.cartesian = FALSE, multivar_settings = build_multivar_settings() )
by.x |
character string. Variable to merge on in data1. See |
by.y |
character string. Variable to merge on in data2. See |
check_merge |
logical. Checks that your unique_keys are indeed unique. |
match_type |
string. If 'exact', match is exact, if 'fuzzy', match is
fuzzy. If 'multivar,' match is multivar-based. See |
fuzzy_settings |
additional arguments for amatch, to be used if match_type = 'fuzzy'. Suggested defaults provided. (see amatch, method='jw') |
score_settings |
list. Score settings for post-hoc matchscores. |
filter |
function or numeric. Filters a merged data1-data2 dataset. If a function, should take in a data.frame (data1 and data2 merged by name1 and name2) and spit out a trimmed version of the data.frame (fewer rows). Think of this function as applying other conditions to matches, other than a match by name. The first argument of filter should be the data.frame. If numeric, will drop all observations with a matchscore lower than or equal to filter. |
filter.args |
list. Arguments passed to filter, if a function |
evaluate |
Function to evaluate merge_plus output. |
evaluate.args |
list. Arguments passed to evaluate |
clean_settings |
list. Settings for string cleaning. See |
clean |
Boolean, T/F, whether or not to clean strings prior to the match. |
sequential_words |
data.table of words in the same format of the common_words argument in |
allow.cartesian |
whether or not to allow many-many matches, see data.table::merge() |
multivar_settings |
list of settings to go to the multivar match if match_type
== 'multivar'. See |
a list containing 1 tier for the 'tier_list' argument of tier_match
.
Calculate weights for comparison variables based on and
probabilities estimated from a verified dataset.
calculate_weights( data, variables, compare_type = "stringdist", suffixes = c("_1", "_2"), non_negative = FALSE )
calculate_weights( data, variables, compare_type = "stringdist", suffixes = c("_1", "_2"), non_negative = FALSE )
data |
data.frame. Verified data. Should have all of the variables you want to calculate weights for from both datasets, named the same with data-specific suffixes. |
variables |
character vector of the variable names of the variables you want to calculate weights for. |
compare_type |
character vector. One of 'stringdist' (for string variables) 'ratio','difference' (for numerics) 'indicator' (0-1 dummy indicating if the two are the same),'in' (0-1 dummy indicating if data1 is IN data2), and 'substr' (numeric indicating how many digits are the same.) |
suffixes |
character vector. Suffixes of of the variables that indicate what data they are from. Default is same as the default for base R merge, c('.x','.y') |
non_negative |
logical. Do you want to allow negative weights? |
This function uses the classic Record Linkage methodology first developed by Felligi and Sunter.
See Record Linkage. is the
probability of a given link between observations is a true match, while
is the probability
of an unlinked pair of observations being a true match.
calculate_weights
computes a preliminary weight for each variable by computing
then making these weights sum to 1. Thus, the weights that have higher
and lower
probabilities will get higher weights, which makes sense given
the definitions. These weights can then be easily passed into the
score_settings
argument of merge_plus
or tier_match
, or into the wgts
argument of
multivar_match
.
list with m probabilities, u probabilities, w weights, and settings, the list argument required as an input for score_settings in merge_plus using the calculate weights.
clean_strings
takes a string vector and cleans it according to user-given options.
clean_strings( string, sp_char_words = fedmatch::sp_char_words, common_words = NULL, remove_char = NULL, remove_words = FALSE, stem = FALSE )
clean_strings( string, sp_char_words = fedmatch::sp_char_words, common_words = NULL, remove_char = NULL, remove_words = FALSE, stem = FALSE )
string |
character or character vector of strings |
sp_char_words |
character vector. Data.frame where first column is special characters and second column is full words. The default is |
common_words |
data.frame. Data.frame where first column is abbreviations and second column is full words. |
remove_char |
character vector. string of specific characters (for example, "letters") to be removed |
remove_words |
logical. If TRUE, removes all abbreviations and replacement words in common_words |
stem |
logical. If TRUE, words are stemmed |
This function takes a variety of options, each of which changes the behavior.
Without the default settings, clean_strings
will do the following:
make the string lowercase; replace special characters &, $, \
names ("and", "dollar", "percent", "at"); convert tabs to spaces and removes extra spaces.
This default cleaning puts the strings in a standard format to allow for easier matching.
The other options allow for the removal or replacement of other words or characters.
cleaned strings
Some made up data on the top 10 US companies in the Fortune 500. Mock-matched to corp_data2 in examples/match_template.R
corp_data1
corp_data1
An object of class data.table
(inherits from data.frame
) with 10 rows and 6 columns.
Some made up data on the top 10 US companies in the Fortune 500. Mock-matched to corp_data1 in examples/match_template.R
corp_data2
corp_data2
An object of class data.table
(inherits from data.frame
) with 10 rows and 6 columns.
Data.frame with common corporate abbreviations in column 1 and corresponding long names in column 2. Useful for cleaning company names for matching.
corporate_words
corporate_words
An object of class data.table
(inherits from data.frame
) with 54 rows and 2 columns.
clean_strings
Data.frame with abbreviations common in the names of financial (i.e. mutual) funds in column 1 and corresponding long names in column 2. Useful for cleaning fund names for matching.
fund_words
fund_words
An object of class data.frame
with 63 rows and 2 columns.
clean_strings
Use the stringdist
package to perform a fuzzy match on two datasets.
fuzzy_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes, unique_key_1, unique_key_2, fuzzy_settings = list(method = "jw", p = 0.1, maxDist = 0.05, matchNA = FALSE, nthread = getOption("sd_num_thread")) )
fuzzy_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes, unique_key_1, unique_key_2, fuzzy_settings = list(method = "jw", p = 0.1, maxDist = 0.05, matchNA = FALSE, nthread = getOption("sd_num_thread")) )
data1 |
data.frame. First to-merge dataset. |
data2 |
data.frame. Second to-merge dataset. |
by |
character string. Variables to merge on (common across data 1 and data 2). See |
by.x |
character string. Variable to merge on in data1. See |
by.y |
character string. Variable to merge on in data2. See |
suffixes |
character vector with length==2. Suffix to add to like named variables after the merge. See |
unique_key_1 |
character vector. Primary key of data1 that uniquely identifies each row (can be multiple fields) |
unique_key_2 |
character vector. Primary key of data2 that uniquely identifies each row (can be multiple fields) |
fuzzy_settings |
list of arguments to pass to to the fuzzy matching function. See |
stringdist
amatch
computes string distances between every
pair of strings in two vectors, then picks the closest string pair for each
observation in the dataset. This is used by fuzzy_match
to perform
a string distance-based match between two datasets. This process can take quite a long time,
for quicker matches try adjusting the nthread
argument in fuzzy_settings
.
The default fuzzy_settings are sensible starting points for company name matching,
but adjusting these can greatly change how the match performs.
a data.table, the resultant merged data set, including all columns from both data sets.
match_evaluate
takes in matches and outputs summary statistics for those matches, including
the number of matches in each tier and the percent matched from each dataset.
match_evaluate( matches, data1, data2, unique_key_1, unique_key_2, suffixes = c("_1", "_1"), tier = "tier", tier_order = NULL, quality_vars = NULL )
match_evaluate( matches, data1, data2, unique_key_1, unique_key_2, suffixes = c("_1", "_1"), tier = "tier", tier_order = NULL, quality_vars = NULL )
matches |
data.frame. Merged dataset. |
data1 |
data.frame. First to-merge dataset. |
data2 |
data.frame. Second to-merge dataset. |
unique_key_1 |
character vector. Primary key of data1 that uniquely identifies each row (can be multiple fields) |
unique_key_2 |
character vector. Primary key of data2 that uniquely identifies each row (can be multiple fields) |
suffixes |
character vector. Mnemonics associated data1 and data2. |
tier |
character vector. Default=NULL. The variable that defines a tier. |
tier_order |
character vector. Default= "tier". Variable that defines the order of tiers, if needed. |
quality_vars |
character vector. Variables you want to use to calculate the quality of each tier. Calculates mean. |
The most straightforward way to use match_evaluate
is to pass it to the evaluate
argument of tier_match
or merge_plus
. This will have merge_plus
return a data.table with the evaluation information, alongside the matches themselves.
I
match_evaluate
returns the number of matches in each tier, the number of
unique matches in each tier, and the percent matched for each dataset. If no tiers are supplied,
the entire dataset will be used as one "tier."
The argument quality_vars
allows for the calculation of averages of any columns in the dataset, by tier.
The most straightforward case would be a matchscore, which can again all be done
in merge_plus
with the scoring argument. This lets you see the average matchscore by tier.
data.table. Table describing each tier according to aggregate_by variables and quality_vars variables.
merge_plus
merge_plus
is a wrapper for a standard merge, a fuzzy string match,
and a a “multivar” match based on several columns of the data. Parameters allow
for control for fine-tuning of the match. This is primarily used as the
workhorse for the tier_match
function.
merge_plus( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes = c("_1", "_2"), check_merge = TRUE, unique_key_1, unique_key_2, match_type = "exact", fuzzy_settings = build_fuzzy_settings(), score_settings = NULL, filter = NULL, filter.args = list(), evaluate = match_evaluate, evaluate.args = list(), allow.cartesian = FALSE, multivar_settings = build_multivar_settings() )
merge_plus( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes = c("_1", "_2"), check_merge = TRUE, unique_key_1, unique_key_2, match_type = "exact", fuzzy_settings = build_fuzzy_settings(), score_settings = NULL, filter = NULL, filter.args = list(), evaluate = match_evaluate, evaluate.args = list(), allow.cartesian = FALSE, multivar_settings = build_multivar_settings() )
data1 |
data.frame. First to-merge dataset (ordering matters - see Fuzzy Matching vignette.) |
data2 |
data.frame. Second to-merge dataset. |
by |
character string. Variables to merge on (common across data 1 and
data 2). See |
by.x |
length-1 character vector. Variable to merge on in data1. See |
by.y |
length-1 character vector. Variable to merge on in data2. See |
suffixes |
character vector with length==2. Suffix to add to like named
variables after the merge. See |
check_merge |
logical. Checks that your unique_keys are indeed unique. |
unique_key_1 |
character vector. Primary key of data1 that uniquely identifies each row (can be multiple fields) |
unique_key_2 |
character vector. Primary key of data2 that uniquely identifies each row (can be multiple fields) |
match_type |
string. If 'exact', match is exact, if 'fuzzy', match is
fuzzy. If 'multivar,' match is multivar-based. See |
fuzzy_settings |
additional arguments for amatch, to be used if match_type
= 'fuzzy'. Suggested defaults provided. See |
score_settings |
list. Score settings for post-hoc matchscores. See |
filter |
function or numeric. Filters a merged data1-data2 dataset. If a function, should take in a data.frame (data1 and data2 merged by name1 and name2) and spit out a trimmed version of the data.frame (fewer rows). Think of this function as applying other conditions to matches, other than a match by name. The first argument of filter should be the data.frame. If numeric, will drop all observations with a matchscore lower than or equal to filter. |
filter.args |
list. Arguments passed to filter, if a function |
evaluate |
Function to evaluate merge_plus output. |
evaluate.args |
list. Arguments passed to evaluate |
allow.cartesian |
whether or not to allow many-many matches, see data.table::merge() |
multivar_settings |
list of settings to go to the multivar match if match_type
== 'multivar'. See |
list with matches, filtered matches (if applicable), data1 and data2 minus matches, and match evaluation
match_evaluate
multivar_match
computes a multivar_score between each pair of observations between
datasets x and y using several variables, then executes a merge by picking the
highest multivar_score pair for each observation in x.
multivar_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, unique_key_1, unique_key_2, logit = NULL, missing = FALSE, wgts = NULL, compare_type = "diff", blocks = NULL, blocks.x = NULL, blocks.y = NULL, nthread = 1, top = 1, threshold = NULL, suffixes = c("_1", "_2") )
multivar_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, unique_key_1, unique_key_2, logit = NULL, missing = FALSE, wgts = NULL, compare_type = "diff", blocks = NULL, blocks.x = NULL, blocks.y = NULL, nthread = 1, top = 1, threshold = NULL, suffixes = c("_1", "_2") )
data1 |
data.frame. First to-merge dataset. |
data2 |
data.frame. Second to-merge dataset. |
by |
character string. Variables to merge on (common across data 1 and data 2). See |
by.x |
character string. Variable to merge on in data1. See |
by.y |
character string. Variable to merge on in data2. See |
unique_key_1 |
character vector. Primary key of data1 that uniquely identifies each row (can be multiple fields) |
unique_key_2 |
character vector. Primary key of data2 that uniquely identifies each row (can be multiple fields) |
logit |
a glm or lm model as a result from a logit regression on a verified dataset. See details. |
missing |
boolean T/F, whether or not to treat missing (NA) observations as its own binary column for each column in by. See details. |
wgts |
rather than a lm model, you can supply weights to calculate multivar_score. Can be weights from |
compare_type |
a vector with the same length as "by" that describes how to compare the variables. Options are "in", "indicator", "substr", "difference", "ratio", "stringdist", and "wgt_jaccard_dist". See the Multivar Matching Vignette for details. |
blocks |
variable present in both data sets to "block" on before computing scores. multivar_scores will only be computed for observations that share a block. See details. |
blocks.x |
name of blocking variables in x. cannot supply both blocks and blocks.x |
blocks.y |
name of blocking variables in y. cannot supply both blocks and blocks.y |
nthread |
integer. Number of cores to use when computing all combinations. See |
top |
integer. Number of matches to return for each observation. |
threshold |
numeric. Minimum score for a match to be included in the result. |
suffixes |
see |
The best way to understand this function is to see the vignette 'Multivar_matching'.
There are two ways of performing this match: either with or without a pre-trained logit.
To use a logit, you must have a verified set of matches. The names of the variables
in this set must match the names of the variables in the data you pass into multivar_match
.
Without a pre-trained logit, you must have a set of weights for each variable that you
want in the comparison. These can either be made up ahead of time, or you can
use a verified set of matches and calculate_weights
.
a data.table, the resultant match, including columns from both data sets.
Common special characters and their replacements for string cleaning
sp_char_words
sp_char_words
An object of class data.table
(inherits from data.frame
) with 4 rows and 2 columns.
Data.table with state FIPS codes and abbreviations.
State_FIPS
State_FIPS
An object of class data.table
(inherits from data.frame
) with 55 rows and 3 columns.
Constructs a tier_match by running merge_plus
with different parameters sequentially
on the same data. Allows for sequential removal of observations after each tier.
tier_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes = c("_1", "_2"), check_merge = TRUE, unique_key_1, unique_key_2, tiers = list(), takeout = "both", match_type = "exact", clean = FALSE, clean_settings = build_clean_settings(), score_settings = NULL, filter = NULL, filter.args = list(), evaluate = match_evaluate, evaluate.args = list(), allow.cartesian = TRUE, fuzzy_settings = build_fuzzy_settings(), multivar_settings = build_multivar_settings(), verbose = FALSE )
tier_match( data1, data2, by = NULL, by.x = NULL, by.y = NULL, suffixes = c("_1", "_2"), check_merge = TRUE, unique_key_1, unique_key_2, tiers = list(), takeout = "both", match_type = "exact", clean = FALSE, clean_settings = build_clean_settings(), score_settings = NULL, filter = NULL, filter.args = list(), evaluate = match_evaluate, evaluate.args = list(), allow.cartesian = TRUE, fuzzy_settings = build_fuzzy_settings(), multivar_settings = build_multivar_settings(), verbose = FALSE )
data1 |
data.frame. First to-merge dataset. |
data2 |
data.frame. Second to-merge dataset. |
by |
character string. Variables to merge on (common across data 1 and data 2). See |
by.x |
character string. Variable to merge on in data1. See |
by.y |
character string. Variable to merge on in data2. See |
suffixes |
see |
check_merge |
logical. Checks that your unique_keys are indeed unique, and prevents merge from running if merge would result in data.frames larger than 5 million rows |
unique_key_1 |
character vector. Primary key of data1 that uniquely identifies each row (can be multiple fields) |
unique_key_2 |
character vector. Primary key of data2 that uniquely identifies each row (can be multiple fields) |
tiers |
list(). tier is a list of lists, where each list holds the parameters for creating that tier. All arguments to tier_match listed after this argument can either be supplied directly to tier_match, or indirectly via tiers. |
takeout |
character vector, either 'data1', 'data2', 'both', or 'neither'. Removes observations after each tier from the selected dataset. |
match_type |
string. If 'exact', match is exact, if 'fuzzy', match is fuzzy. |
clean |
Boolean, T/F, whether or not to clean strings prior to the match. |
clean_settings |
list. Settings for string cleaning. See |
score_settings |
list. Settings for post-hoc matchscoring. See |
filter |
function or numeric. Filters a merged data1-data2 dataset. If a function, should take in a data.frame (data1 and data2 merged by name1 and name2) and spit out a trimmed version of the data.frame (fewer rows). Think of this function as applying other conditions to matches, other than a match by name. The first argument of filter should be the data.frame. If numeric, will drop all observations with a matchscore lower than or equal to filter. |
filter.args |
list. Arguments passed to filter, if a function |
evaluate |
Function to evaluate merge_plus output. see |
evaluate.args |
list. Arguments passed to function specified by evaluate |
allow.cartesian |
whether or not to allow many-many matches, see data.table::merge() |
fuzzy_settings |
additional arguments for amatch, to be used if match_type = 'fuzzy'. Suggested defaults provided. (see amatch, method='jw') |
multivar_settings |
list of settings to go to the multivar match if match_type
== 'multivar'. See |
verbose |
boolean, whether or not to print tier names and time to match each tier as the matching happens. |
See the tier match vignette to get a clear understanding of the tier_match syntax.
list with matches, data1 and data2 minus matches, and match evaluation
merge_plus clean_strings
#' wgt_jaccard_distance
computes the Weighted Jaccard Distance between
two strings. It is vectorized, and accepts only two equal-length string
vectors.
wgt_jaccard_distance(string_1, string_2, corpus, nthreads = 1)
wgt_jaccard_distance(string_1, string_2, corpus, nthreads = 1)
string_1 |
character vector |
string_2 |
character vector |
corpus |
corpus data.table, constructed with
|
nthreads |
number of threads to use in the underlying C++ code |
See the vignette fuzzy_matching
for details on how the Weighted Jaccard similarity is computed.
numeric vector with the Weighted Jaccard distances for each element of string_1 and string_2.
word_frequency
counts the frequency of words in a set of strings.
Also does minimal cleaning (removes punctuation and extra spaces). Useful for
determining what words are common and may need to be replaced or removed with
clean_strings
.
word_frequency(string)
word_frequency(string)
string |
character vector |
data.table with word frequency
World Bank 3-Character Country Codes for 213 countries
World_Bank_Codes
World_Bank_Codes
An object of class data.table
(inherits from data.frame
) with 213 rows and 2 columns.