R/add_col.R

#' Add a colum to a data frame
#'
#' Similar to cbind, but allows you to specify the positoin. Will replac
#' existing variable with the same name if present.
#'
#' @param x A data frame
#' @param name Name of variabl to create. If variable of that name
#'   already exists
#' @param value Values to insert.
#' @param where position to insert. Use 1 to insert on LHS.
#'   RHS.
#' @export
#' @examples
#' df <- data.frame(x = 1:5)
#' add_col(df, "y", runif(5))
#' add_col(df, "y", runif(5), where = 1)
#'
#' add_col(df, "x", 5:1)
add_col <- function(x, name, value, where = ncol(x) + 1) {
  if (name %in% names(x)) {
    x[[name]] <- value
    x
  } else {
    df <- setNames(data.frame(value), name)
    insert_into(x, df, where = where)
  }
}
hadley/hadcol documentation built on May 31, 2019, 10:47 p.m.