knitr::opts_chunk$set( collapse = TRUE, comment = "#>", fig.path = "man/figures/README-", out.width = "100%" )
As of safejoin
version 0.2.0 the package has been deprecated. As of version 1.1.1
dplyr has a relationship
argument that provides the same functionality that safejoin
was created for. See the dplyr docs https://dplyr.tidyverse.org/reference/mutate-joins.html for complete details.
Please use dplyr::left_join()
with the relationship
argument instead.
The goal of safejoin is to guarantee that when performing joins that extra rows are not added to your data. safejoin is a wrapper around the dplyr::left_join
function.
You can install the released version of safejoin from CRAN with:
install.packages("safejoin")
Install development version from GitHub:
devtools::install_github("SamEdwardes/safejoin", ref = "dev")
Depending on your need safejoin can raise an error, a warning, or a message. By default safejoin will raise an error.
Error:
library(safejoin) x <- data.frame(key = c("a", "b"), value_x = c(1, 2)) y <- data.frame(key = c("a", "a"), value_y = c(1, 1)) safe_left_join(x, y, by = "key")
Warning:
safe_left_join(x, y, by = "key", action="warning")
Message:
safe_left_join(x, y, by = "key", action="message")
When a join is "safe" safe_left_join
will have the exact same behavior as dplyr::left_join
.
x <- data.frame(key = c("a", "b"), value_x = c(1, 2)) y <- data.frame(key = c("a", "b"), value_y = c(1, 1)) safe_left_join(x, y, by = "key")
There are other packages that help solve similar problems. Most notably https://github.com/cynkra/dm provides great features to treat data frames like a data base.
safejoin is created and maintained by Sam Edwardes.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.