Learn R Programming

sjmisc - Data and Variable Transformation Functions

           

Data preparation is a common task in research, which usually takes the most amount of time in the analytical process. Packages for data preparation have been released recently as part of the tidyverse, focussing on the transformation of data sets. Packages with special focus on transformation of variables, which fit into the workflow and design-philosophy of the tidyverse, are missing.

sjmisc tries to fill this gap. Basically, this package complements the dplyr package in that sjmisc takes over data transformation tasks on variables, like recoding, dichotomizing or grouping variables, setting and replacing missing values, etc. A distinctive feature of sjmisc is the support for labelled data, which is especially useful for users who often work with data sets from other statistical software packages like SPSS or Stata.

The functions of sjmisc are designed to work together seamlessly with other packages from the tidyverse, like dplyr. For instance, you can use the functions from sjmisc both within a pipe-workflow to manipulate data frames, or to create new variables with mutate(). See vignette("design_philosophy", "sjmisc") for more details.

Contributing to the package

Please follow this guide if you like to contribute to this package.

Installation

Latest development build

To install the latest development snapshot (see latest changes below), type following commands into the R console:

library(devtools)
devtools::install_github("strengejacke/sjmisc")

Officiale, stable release

To install the latest stable release from CRAN, type following command into the R console:

install.packages("sjmisc")

References, documentation and examples

Please visit https://strengejacke.github.io/sjmisc/ for documentation and vignettes.

Citation

In case you want / have to cite my package, please cite as (see also citation('sjmisc')):

Lüdecke D (2018). sjmisc: Data and Variable Transformation Functions. Journal of Open Source Software, 3(26), 754. doi: 10.21105/joss.00754

Copy Link

Version

Install

install.packages('sjmisc')

Monthly Downloads

36,344

Version

2.8.10

License

GPL-3

Maintainer

Last Published

May 13th, 2024

Functions in sjmisc (2.8.10)

%nin%

Value matching
flat_table

Flat (proportional) tables
is_crossed

Check whether two factors are crossed or nested
is_empty

Check whether string, list or vector is empty
frq

Frequency table of labelled variables
group_str

Group near elements of string vectors
group_var

Recode numeric variables into equal-ranged groups
has_na

Check if variables or cases have missing / infinite values
empty_cols

Return or remove variables or observations that are completely missing
find_var

Find variable by name or label
numeric_to_factor

Convert numeric vectors into factors associated value labels
rec_pattern

Create recode pattern for 'rec' function
rec

Recode variables
move_columns

Move columns to other positions in a data frame
is_num_fac

Check whether a factor has numeric levels only
merge_imputations

Merges multiple imputed data frames into a single data frame
is_even

Check whether value is even or odd
reexports

Objects exported from other packages
is_float

Check if a variable is of (non-integer) double type or a whole number
recode_to

Recode variable categories into new values
reshape_longer

Reshape data into long format
seq_col

Sequence generation for column or row counts of data frames
round_num

Round numeric variables in a data frame
set_na_if

Replace specific values in vector with NA
row_count

Count row or column indices
replace_na

Replace NA with specific values
ref_lvl

Change reference level of (numeric) factors
rotate_df

Rotate a data frame
remove_var

Remove variables from a data frame
row_sums

Row sums and means for data frames
shorten_string

Shorten character strings
split_var

Split numeric variables into smaller groups
spread_coef

Spread model coefficients of list-variables into columns
std

Standardize and center variables
str_contains

Check if string contains pattern
tidy_values

Clean values of character vectors.
to_dummy

Split (categorical) vectors into dummy variables
str_start

Find start and end index of pattern in string
str_find

Find partial matching and close distance elements in strings
sjmisc-package

Data and Variable Transformation Functions
trim

Trim leading and trailing whitespaces from strings
typical_value

Return the typical value of a vector
to_long

Convert wide data to long format
to_value

Convert factors to numeric variables
word_wrap

Insert line breaks in long labels
zap_inf

Convert infiite or NaN values into regular NA
var_rename

Rename variables
var_type

Determine variable type
descr

Basic descriptive statistics
add_variables

Add variables or cases to data frames
dicho

Dichotomize variables
big_mark

Format numbers
add_rows

Merge labelled data frames
efc

Sample dataset from the EUROFAMCARE project
all_na

Check if vector only has NA values
de_mean

Compute group-meaned and de-meaned variables
add_columns

Add or replace data frame columns
count_na

Frequency table of tagged NA values