BREAKING CHANGES AND DEPRECATIONS
-
datawizard now requires R >= 4.0 (#515).
-
Argument
drop_na
indata_match()
is deprecated now. Please useremove_na
instead (#556). -
In
data_rename()
(#567):- argument
pattern
is deprecated. Useselect
instead. - argument
safe
is deprecated. The function now errors whenselect
contains unknown column names. - when
replacement
isNULL
, an error is now thrown (previously, column indices were used as new names). - if
select
(previouslypattern
) is a named vector, then all elements must be named, e.g.c(length = "Sepal.Length", "Sepal.Width")
errors.
- argument
-
Order of arguments
by
andprobability_weights
inrescale_weights()
has changed, because formethod = "kish"
, theby
argument is optional (#575). -
The name of the rescaled weights variables in
rescale_weights()
have been renamed.pweights_a
andpweights_b
are now namedrescaled_weights_a
andrescaled_weights_b
(#575). -
print()
methods fordata_tabulate()
with multiple sub-tables (i.e. when length ofby
was > 1) were revised. Now, an integrated table instead of multiple tables is returned. Furthermore,print_html()
did not work, which was also fixed now (#577). -
demean()
(anddegroup()
) gets anappend
argument that defaults toTRUE
, to append the centered variables to the original data frame, instead of returning the de- and group-meaned variables only. Useappend = FALSE
to for the previous default behaviour (i.e. only returning the newly created variables) (#579).
CHANGES
-
rescale_weights()
gets amethod
argument, to choose method to rescale weights. Options are"carle"
(the default) and"kish"
(#575). -
The
select
argument, which is available in different functions to select variables, can now also be a character vector with quoted variable names, including a colon to indicate a range of several variables (e.g."cyl:gear"
) (#551). -
New function
row_sums()
, to calculate row sums (optionally with minimum amount of valid values), as complement torow_means()
(#552). -
New function
row_count()
, to count specific values row-wise (#553). -
data_read()
no longer shows warning about forthcoming breaking changes in upstream packages when reading.RData
files (#557). -
data_modify()
now recognizesn()
, for example to create an index for data groups with1:n()
(#535). -
The
replacement
argument indata_rename()
now supports glue-styled tokens (#563). -
data_summary()
also accepts the results ofbayestestR::ci()
as summary function (#483). -
ranktransform()
has a new argumentzeros
to determine how zeros should be handled whensign = TRUE
(#573).
BUG FIXES
-
describe_distribution()
no longer errors if the sample was too sparse to compute CIs. Instead, it warns the user and returnsNA
(#550). -
data_read()
preserves variable types when importing files fromrds
orrdata
format (#558).
BREAKING CHANGES
-
data_rename()
now errors when thereplacement
argument containsNA
values or empty strings (#539). -
Removed deprecated functions
get_columns()
,data_find()
,format_text()
(#546). -
Removed deprecated arguments
group
andna.rm
in multiple functions. Useby
andremove_na
instead (#546). -
The default value for the argument
dummy_factors
into_numeric()
has changed fromTRUE
toFALSE
(#544).
CHANGES
-
The
pattern
argument indata_rename()
can also be a named vector. In this case, names are used as values for thereplacement
argument (i.e.pattern
can be a character vector using<new name> = "<old name>"
). -
categorize()
gains a newbreaks
argument, to decide whether breaks are inclusive or exclusive (#548). -
The
labels
argument incategorize()
gets two new options,"range"
and"observed"
, to use the range of categorized values as labels (i.e. factor levels) (#548). -
Minor additions to
reshape_ci()
to work with forthcoming changes in the{bayestestR}
package.
CHANGES
-
demean()
(anddegroup()
) now also work for nested designs, if argumentnested = TRUE
andby
specifies more than one variable (#533). -
Vignettes are no longer provided in the package, they are now only available on the website. There is only one "Overview" vignette available in the package, it contains links to the other vignettes on the website. This is because there are CRAN errors occurring when building vignettes on macOS and we couldn't determine the cause after multiple patch releases (#534).
- Remove
htmltools
fromSuggests
in an attempt of fixing an error in CRAN checks due to failures to build a vignette (#528).
This is a patch release to fix one error on CRAN checks occurring because of a missing package namespace in one of the vignettes.
BREAKING CHANGES
-
The argument
include_na
indata_tabulate()
anddata_summary()
has been renamed intoremove_na
. Consequently, to mimic former behaviour,FALSE
andTRUE
need to be switched (i.e.remove_na = TRUE
is equivalent to the formerinclude_na = FALSE
). -
Class names for objects returned by
data_tabulate()
have been changed todatawizard_table
anddatawizard_crosstable
(resp. the plural forms,*_tables
), to provide a clearer and more consistent naming scheme.
CHANGES
-
data_select()
can directly rename selected variables when a named vector is provided inselect
, e.g.data_select(mtcars, c(new1 = "mpg", new2 = "cyl"))
. -
data_tabulate()
gains anas.data.frame()
method, to return the frequency table as a data frame. The structure of the returned object is a nested data frame, where the first column contains name of the variable for which frequencies were calculated, and the second column contains the frequency table. -
demean()
(anddegroup()
) now also work for cross-classified designs, or more generally, for data with multiple grouping or cluster variables (i.e.by
can now specify more than one variable).
BREAKING CHANGES
-
Arguments named
group
orgroup_by
are deprecated and will be removed in a future release. Please useby
instead. This affects the following functions in datawizard (#502).data_partition()
demean()
anddegroup()
means_by_group()
rescale_weights()
-
Following aliases are deprecated and will be removed in a future release (#504):
get_columns()
, usedata_select()
instead.data_find()
andfind_columns()
, useextract_column_names()
instead.format_text()
, usetext_format()
instead.
CHANGES
-
recode_into()
is more relaxed regarding checking the type ofNA
values. If you recode into a numeric variable, and one of the recode values isNA
, you no longer need to useNA_real_
for numericNA
values. -
Improved documentation for some functions.
BUG FIXES
data_to_long()
did not work for data frame where columns had attributes (like labelled data).
BREAKING CHANGES
-
The following arguments were deprecated in 0.5.0 and are now removed:
- in
data_to_wide()
:colnames_from
,rows_from
,sep
- in
data_to_long()
:colnames_to
- in
data_partition()
:training_proportion
- in
NEW FUNCTIONS
-
data_summary()
, to compute summary statistics of (grouped) data frames. -
data_replicate()
, to expand a data frame by replicating rows based on another variable that contains the counts of replications per row.
CHANGES
-
data_modify()
gets three new arguments,.at
,.if
and.modify
, to modify variables at specific positions or based on logical conditions. -
data_tabulate()
was revised and gets several new arguments: aweights
argument, to compute weighted frequency tables.include_na
allows to include or omit missing values from the table. Furthermore, aby
argument was added, to compute crosstables (#479, #481).
CHANGES
-
rescale()
gainsmultiply
andadd
arguments, to expand ranges by a given factor or value. -
to_factor()
andto_numeric()
now support classhaven_labelled
.
BUG FIXES
-
to_numeric()
now correctly deals with inversed factor levels whenpreserve_levels = TRUE
. -
to_numeric()
inversed order of value labels whendummy_factors = FALSE
. -
convert_to_na()
now preserves attributes for factors whendrop_levels = TRUE
.
NEW FUNCTIONS
-
row_means()
, to compute row means, optionally only for the rows with at leastmin_valid
non-missing values. -
contr.deviation()
for sum-deviation contrast coding of factors. -
means_by_group()
, to compute mean values of variables, grouped by levels of specified factors. -
data_seek()
, to seek for variables in a data frame, based on their column names, variables labels, value labels or factor levels. Searching for labels only works for "labelled" data, i.e. when variables have alabel
orlabels
attribute.
CHANGES
-
recode_into()
gains anoverwrite
argument to skip overwriting already recoded cases when multiple recode patterns apply to the same case. -
recode_into()
gains anpreserve_na
argument to preserveNA
values when recoding. -
data_read()
now passes theencoding
argument todata.table::fread()
. This allows to read files with non-ASCII characters. -
datawizard
moves from the GPL-3 license to the MIT license. -
unnormalize()
andunstandardize()
now work with grouped data (#415). -
unnormalize()
now errors instead of emitting a warning if it doesn't have the necessary info (#415).
BUG FIXES
-
Fixed issue in
labels_to_levels()
when values of labels were not in sorted order and values were not sequentially numbered. -
Fixed issues in
data_write()
when writing labelled data into SPSS format and vectors were of different type as value labels. -
Fixed issues in
data_write()
when writing labelled data into SPSS format for character vectors with missing value labels, but existing variable labels. -
Fixed issue in
recode_into()
with probably wrong case number printed in the warning when several recode patterns match to one case. -
Fixed issue in
recode_into()
when original data containedNA
values andNA
was not included in the recode pattern. -
Fixed issue in
data_filter()
where functions containing a=
(e.g. when naming arguments, likegrepl(pattern, x = a)
) were mistakenly seen as faulty syntax. -
Fixed issue in
empty_column()
for strings with invalid multibyte strings. For such data frames or files,empty_column()
ordata_read()
no longer fails.
BREAKING CHANGES
-
The following re-exported functions from
{insight}
have now been removed:object_has_names()
,object_has_rownames()
,is_empty_object()
,compact_list()
,compact_character()
. -
Argument
na.rm
was renamed toremove_na
throughout{datawizard}
functions.na.rm
is kept for backward compatibility, but will be deprecated and later removed in future updates. -
The way expressions are defined in
data_filter()
was revised. Thefilter
argument was replaced by...
, allowing to separate multiple expression with a comma (which are then combined with&
). Furthermore, expressions can now also be defined as strings, or be provided as character vectors, to allow string-friendly programming.
CHANGES
-
Weighted-functions (
weighted_sd()
,weighted_mean()
, ...) gain aremove_na
argument, to remove or keep missing and infinite values. By default,remove_na = TRUE
, i.e. missing and infinite values are removed by default. -
reverse_scale()
,normalize()
andrescale()
gain anappend
argument (similar to other data frame methods of transformation functions), to append recoded variables to the input data frame instead of overwriting existing variables.
NEW FUNCTIONS
-
rowid_as_column()
to complementrownames_as_column()
(and to mimictibble::rowid_to_column()
). Note that its behavior is different fromtibble::rowid_to_column()
for grouped data. See the Details section in the docs. -
data_unite()
, to merge values of multiple variables into one new variable. -
data_separate()
, as counterpart todata_unite()
, to separate a single variable into multiple new variables. -
data_modify()
, to create new variables, or modify or remove existing variables in a data frame.
MINOR CHANGES
-
to_numeric()
for variables of typeDate
,POSIXct
andPOSIXlt
now includes the class name in the warning message. -
Added a
print()
method forcenter()
,standardize()
,normalize()
andrescale()
.
BUG FIXES
-
standardize_parameters()
now works when the package namespace is in the model formula (#401). -
data_merge()
no longer yields a warning fortibbles
whenjoin = "bind"
. -
center()
andstandardize()
did not work for grouped data frames (of classgrouped_df
) whenforce = TRUE
. -
The
data.frame
method ofdescribe_distribution()
returnsNULL
instead of an error if no valid variable were passed (for example a factor variable withinclude_factors = FALSE
) (#421).
BREAKING CHANGES
add_labs()
was renamed intoassign_labels()
. Sinceadd_labs()
existed only for a few days, there will be no alias for backwards compatibility.
NEW FUNCTIONS
labels_to_levels()
, to use value labels of factors as their levels.
MINOR CHANGES
data_read()
now checks if the imported object actually is a data frame (or coercible to a data frame), and if not, no longer errors, but gives an informative warning of the type of object that was imported.
BUG FIXES
- Fix test for CRAN check on Mac OS arm64
BREAKING CHANGES
-
In selection patterns, expressions like
-var1:var3
to exclude all variables betweenvar1
andvar3
are no longer accepted. The correct expression is-(var1:var3)
. This is for 2 reasons:- to be consistent with the behavior for numerics (
-1:2
is not accepted but-(1:2)
is); - to be consistent with
dplyr::select()
, which throws a warning and only uses the first variable in the first expression.
- to be consistent with the behavior for numerics (
NEW FUNCTIONS
-
recode_into()
, similar todplyr::case_when()
, to recode values from one or more variables into a new variable. -
mean_sd()
andmedian_mad()
for summarizing vectors to their mean (or median) and a range of one SD (or MAD) above and below. -
data_write()
as counterpart todata_read()
, to write data frames into CSV, SPSS, SAS, Stata files and many other file types. One advantage over existing functions to write data in other packages is that labelled (numeric) data can be converted into factors (with values labels used as factor levels) even for text formats like CSV and similar. This allows exporting "labelled" data into those file formats, too. -
add_labs()
, to manually add value and variable labels as attributes to variables. These attributes are stored as"label"
and"labels"
attributes, similar to thelabelled
class from the haven package.
MINOR CHANGES
data_rename()
gets averbose
argument.winsorize()
now errors if the threshold is incorrect (previously, it provided a warning and returned the unchanged data). The argumentverbose
is now useless but is kept for backward compatibility. The documentation now contains details about the valid values forthreshold
(#357).- In all functions that have arguments
select
and/orexclude
, there is now one warning per misspelled variable. The previous behavior was to have only one warning. - Fixed inconsistent behaviour in
standardize()
when only one of the argumentscenter
orscale
were provided (#365). unstandardize()
andreplace_nan_inf()
now work with select helpers (#376).- Added informative warning and error messages to
reverse()
. Furthermore, the docs now describe therange
argument more clearly (#380). unnormalize()
errors with unexpected inputs (#383).
BUG FIXES
empty_columns()
(and thereforeremove_empty_columns()
) now correctly detects columns containing onlyNA_character_
(#349).- Select helpers now work in custom functions when argument is called
select
(#356). - Fix unexpected warning in
convert_na_to()
whenselect
is a list (#352). - Fixed issue with correct labelling of numeric variables with more than nine unique values and associated value labels.
MAJOR CHANGES
- Etienne Bacher is the new maintainer.
MINOR CHANGES
-
standardize()
,center()
,normalize()
andrescale()
can be used in model formulas, similar tobase::scale()
. -
data_codebook()
now includes the proportion for each category/value, in addition to the counts. Furthermore, if data contains taggedNA
values, these are included in the frequency table.
BUG FIXES
-
center(x)
now works correctly whenx
is a single value and eitherreference
orcenter
is specified (#324). -
Fixed issue in
data_codebook()
, which failed for labelled vectors when values of labels were not in sorted order.
NEW FUNCTIONS
-
data_codebook()
: to generate codebooks of data frames. -
New functions to deal with duplicates:
data_duplicated()
(keep all duplicates, including the first occurrence) anddata_unique()
(returns the data, excluding all duplicates except one instance of each, based on the selected method).
MINOR CHANGES
-
.data.frame
methods should now preserve custom attributes. -
The
include_bounds
argument innormalize()
can now also be a numeric value, defining the limit to the upper and lower bound (i.e. the distance to 1 and 0). -
data_filter()
now works with grouped data.
BUG FIXES
-
data_read()
no longer prints message for empty columns when the data actually had no empty columns. -
data_to_wide()
now drops columns that are not inid_cols
(if specified),names_from
, orvalues_from
. This is the behaviour observed intidyr::pivot_wider()
.
MAJOR CHANGES
-
There is a new publication about the
{datawizard}
package: https://joss.theoj.org/papers/10.21105/joss.04684 -
Fixes failing tests due to changes in
R-devel
. -
data_to_long()
anddata_to_wide()
have had significant performance improvements, sometimes as high as a ten-fold speedup.
MINOR CHANGES
-
When column names are misspelled, most functions now suggest which existing columns possibly could be meant.
-
Miscellaneous performance gains.
-
convert_to_na()
now requires argumentna
to be of class 'Date' to convert specific dates toNA
. For example,convert_to_na(x, na = "2022-10-17")
must be changed toconvert_to_na(x, na = as.Date("2022-10-17"))
.
BUG FIXES
data_to_long()
anddata_to_wide()
now correctly keep thedate
format.
BREAKING CHANGES
-
Methods for grouped data frames (
.grouped_df
) no longer supportdplyr::group_by()
for{dplyr}
before version0.8.0
. -
empty_columns()
andremove_empty_columns()
now also remove columns that contain only empty characters. Likewise,empty_rows()
andremove_empty_rows()
remove observations that completely have missing or empty character values.
MINOR CHANGES
data_read()
gains aconvert_factors
argument, to turn off automatic conversion from numeric variables into factors.
BUG FIXES
data_arrange()
now works with data frames that were grouped usingdata_group()
(#274).
- Updates tests for upcoming changes in the
{tidyselect}
package (#267).
BREAKING CHANGES
-
The minimum needed R version has been bumped to
3.6
. -
Following deprecated functions have been removed:
data_cut()
, data_recode()
, data_shift()
, data_reverse()
,
data_rescale()
, data_to_factor()
, data_to_numeric()
-
New
text_format()
alias is introduced forformat_text()
, latter of which will be removed in the next release. -
New
recode_values()
alias is introduced forchange_code()
, latter of which will be removed in the next release. -
data_merge()
now errors if columns specified inby
are not in both datasets. -
Using negative values in arguments
select
andexclude
now removes the columns from the selection/exclusion. The previous behavior was to start the selection/exclusion from the end of the dataset, which was inconsistent with the use of "-" with other selecting possibilities.
NEW FUNCTIONS
-
data_peek()
: to peek at values and type of variables in a data frame. -
coef_var()
: to compute the coefficient of variation.
CHANGES
-
data_filter()
will give more informative messages on malformed syntax of thefilter
argument. -
It is now possible to use curly brackets to pass variable names to
data_filter()
, like the following example. See examples section in the documentation ofdata_filter()
. -
The
regex
argument was added to functions that use select-helpers and did not already have this argument. -
Select helpers
starts_with()
,ends_with()
, andcontains()
now accept several patterns, e.gstarts_with("Sep", "Petal")
. -
Arguments
select
andexclude
that are present in most functions have been improved to work in loops and in custom functions. For example, the following code now works:
foo <- function(data) {
i <- "Sep"
find_columns(data, select = starts_with(i))
}
foo(iris)
for (i in c("Sepal", "Sp")) {
head(iris) |>
find_columns(select = starts_with(i)) |>
print()
}
- There is now a vignette summarizing the various ways to select or exclude
variables in most
{datawizard}
functions.
- Fixes failing tests due to
{poorman}
update.
MAJOR CHANGES
-
Following statistical transformation functions have been renamed to not have
data_*()
prefix, since they do not work exclusively with data frames, but are typically first of all used with vectors, and therefore had misleading names:-
data_cut()
->categorize()
-
data_recode()
->change_code()
-
data_shift()
->slide()
-
data_reverse()
->reverse()
-
data_rescale()
->rescale()
-
data_to_factor()
->to_factor()
-
data_to_numeric()
->to_numeric()
-
Note that these functions also have .data.frame()
methods and still work for
data frames as well. Former function names are still available as aliases, but
will be deprecated and removed in a future release.
-
Bumps the needed minimum R version to
3.5
. -
Removed deprecated function
data_findcols()
. Please use its replacement,data_find()
. -
Removed alias
extract()
fordata_extract()
function since it collided withtidyr::extract()
. -
Argument
training_proportion
indata_partition()
is deprecated. Please useproportion
now. -
Given his continued and significant contributions to the package, Etienne Bacher (@etiennebacher) is now included as an author.
-
unstandardise()
now works forcenter(x)
-
unnormalize()
now works forchange_scale(x)
-
reshape_wider()
now follows more consistentlytidyr::pivot_wider()
syntax. Argumentscolnames_from
,sep
, androws_from
are deprecated and should be replaced bynames_from
,names_sep
, andid_cols
respectively.reshape_wider()
also gains an argumentnames_glue
(#182, #198). -
Similarly,
reshape_longer()
now follows more consistentlytidyr::pivot_longer()
syntax. Argumentcolnames_to
is deprecated and should be replaced bynames_to
.reshape_longer()
also gains new arguments:names_prefix
,names_sep
,names_pattern
, andvalues_drop_na
(#189).
CHANGES
-
Some of the text formatting helpers (like
text_concatenate()
) gain anenclose
argument, to wrap text elements with surrounding characters. -
winsorize
now accepts "raw" and "zscore" methods (in addition to "percentile"). Additionally, whenrobust
is set toTRUE
together withmethod = "zscore"
, winsorizes via the median and median absolute deviation (MAD); else via the mean and standard deviation. (@rempsyc, #177, #49, #47). -
convert_na_to
now accepts numeric replacements on character vectors and single replacement for multiple vector classes. (@rempsyc, #214). -
data_partition()
now allows to create multiple partitions from the data, returning multiple training and a remaining test set. -
Functions like
center()
,normalize()
orstandardize()
no longer fail when data contains infinite values (Inf
).
NEW FUNCTIONS
-
row_to_colnames()
andcolnames_to_row()
to move a row to column names, and column names to row (@etiennebacher, #169). -
data_arrange()
to sort the rows of a dataframe according to the values of the selected columns.
BUG FIXES
- Fixed wrong column names in
data_to_wide()
(#173).
BREAKING
- Added the
standardize.default()
method (moved from package effectsize), to be consistent in that the default-method now is in the same package as the generic.standardize.default()
behaves exactly like in effectsize and particularly works for regression model objects. effectsize now re-exportsstandardize()
from datawizard.
NEW FUNCTIONS
-
data_shift()
to shift the value range of numeric variables. -
data_recode()
to recode old into new values. -
data_to_factor()
as counterpart todata_to_numeric()
. -
data_tabulate()
to create frequency tables of variables. -
data_read()
to read (import) data files (from text, or foreign statistical packages). -
unnormalize()
as counterpart tonormalize()
. This function only works for variables that have been normalized withnormalize()
. -
data_group()
anddata_ungroup()
to create grouped data frames, or to remove the grouping information from grouped data frames.
CHANGES
-
data_find()
was added as alias tofind_colums()
, to have consistent name patterns for the datawizard functions.data_findcols()
will be removed in a future update and usage is discouraged. -
The
select
argument (and thus, also theexclude
argument) now also accepts functions testing for logical conditions, e.g.is.numeric()
(oris.numeric
), or any user-defined function that selects the variables for which the function returnsTRUE
(like:foo <- function(x) mean(x) > 3
). -
Arguments
select
andexclude
now allow the negation of select-helpers, like-ends_with("")
,-is.numeric
or-Sepal.Width:Petal.Length
. -
Many functions now get a
.default
method, to capture unsupported classes. This now yields a message and returns the original input, and hence, the.data.frame
methods won't stop due to an error. -
The
filter
argument indata_filter()
can also be a numeric vector, to indicate row indices of those rows that should be returned. -
convert_to_na()
gets methods for variables of classlogical
andDate
. -
convert_to_na()
for factors (and data frames) gains adrop_levels
argument, to drop unused levels that have been replaced byNA
. -
data_to_numeric()
gains two more arguments,preserve_levels
andlowest
, to give better control of conversion of factors.
BUG FIXES
- When logicals were passed to
center()
orstandardize()
andforce = TRUE
, these were not properly converted to numeric variables.
MAJOR CHANGES
-
data_match()
now returns filtered data by default. Old behavior (returning rows indices) can be set by settingreturn_indices = TRUE
. -
The following functions are now re-exported from
{insight}
package:object_has_names()
,object_has_rownames()
,is_empty_object()
,compact_list()
,compact_character()
-
data_findcols()
will become deprecated in future updates. Please use the new replacementsfind_columns()
andget_columns()
. -
The vignette Analysing Longitudinal or Panel Data has now moved to parameters package.
NEW FUNCTIONS
-
To convert rownames to a column, and vice versa:
rownames_as_column()
andcolumn_as_rownames()
(@etiennebacher, #80). -
find_columns()
andget_columns()
to find column names or retrieve subsets of data frames, based on various select-methods (including select-helpers). These function will supersededata_findcols()
in the future. -
data_filter()
as complement fordata_match()
, which works with logical expressions for filtering rows of data frames. -
For computing weighted centrality measures and dispersion:
weighted_mean()
,weighted_median()
,weighted_sd()
andweighted_mad()
. -
To replace
NA
in vectors and dataframes:convert_na_to()
(@etiennebacher, #111).
MINOR CHANGES
-
The
select
argument in several functions (likedata_remove()
,reshape_longer()
, ordata_extract()
) now allows the use of select-helpers for selecting variables based on specific patterns. -
data_extract()
gains new arguments to allow type-safe return values,
i.e. always return a vector or a data frame. Thus, data_extract()
can now
be used to select multiple variables or pull a single variable from data
frames.
-
data_match()
gains amatch
argument, to indicate with which logical operation matching results should be combined. -
Improved support for labelled data for many functions, i.e. returned data frame will preserve value and variable label attributes, where possible and applicable.
-
describe_distribution()
now works with lists (@etiennebacher, #105). -
data_rename()
doesn't usepattern
anymore to rename the columns ifreplacement
is not provided (@etiennebacher, #103). -
data_rename()
now adds a suffix to duplicated names inreplacement
(@etiennebacher, #103).
BUG FIXES
-
data_to_numeric()
produced wrong results for factors whendummy_factors = TRUE
and factor contained missing values. -
data_match()
produced wrong results when data contained missing values. -
Fixed CRAN check issues in
data_extract()
when more than one variable was extracted from a data frame.
NEW FUNCTIONS
-
To find or remove empty rows and columns in a data frame:
empty_rows()
,empty_columns()
,remove_empty_rows()
,remove_empty_columns()
, andremove_empty
. -
To check for names:
object_has_names()
andobject_has_rownames()
. -
To rotate data frames:
data_rotate()
. -
To reverse score variables:
data_reverse()
. -
To merge/join multiple data frames:
data_merge()
(or its aliasdata_join()
). -
To cut (recode) data into groups:
data_cut()
. -
To replace specific values with
NA
s:convert_to_na()
. -
To replace
Inf
andNaN
values withNA
s:replace_nan_inf()
.
- Arguments
cols
,before
andafter
indata_relocate()
can now also be numeric values, indicating the position of the destination column.
-
New functions:
-
to work with lists:
is_empty_object()
andcompact_list()
-
to work with strings:
compact_character()
-
-
New function
data_extract()
(or its aliasextract()
) to pull single variables from a data frame, possibly naming each value by the row names of that data frame. -
reshape_ci()
gains aci_type
argument, to reshape data frames where CI-columns have prefixes other than"CI"
. -
standardize()
andcenter()
gain argumentscenter
andscale
, to define references for centrality and deviation that are used when centering or standardizing variables. -
center()
gains the argumentsforce
andreference
, similar tostandardize()
. -
The functionality of the
append
argument incenter()
andstandardize()
was revised. This made thesuffix
argument redundant, and thus it was removed. -
Fixed issue in
standardize()
. -
Fixed issue in
data_findcols()
.
-
Exports
plot
method forvisualisation_recipe()
objects from{see}
package. -
centre()
,standardise()
,unstandardise()
are exported as aliases forcenter()
,standardize()
,unstandardize()
, respectively.
- This is mainly a maintenance release that addresses some issues with conflicting namespaces.
-
New function:
visualisation_recipe()
. -
The following function has now moved to performance package:
check_multimodal()
. -
Minor updates to documentation, including a new vignette about
demean()
.
- First release.