R/splitByCommonTails.R

Defines functions splitByCommonTails

Documented in splitByCommonTails

splitByCommonTails <- function(strs, ...) {
  names <- names(strs)

  prefix <- getCommonPrefix(strs)
  suffix <- getCommonPrefix(strs, suffix=TRUE)

  # Cut out the prefix
  body <- substring(strs, nchar(prefix)+1)

  # Cut out the suffix
  body <- substring(body, 1, nchar(body)-nchar(suffix))

  # Special case
  if (all(body == "")) {
    suffix <- ""
  }

  strs <- lapply(body, FUN=function(s) {
    c(prefix, s, suffix)
  })

  strs <- unlist(strs, use.names=FALSE)
  strs <- matrix(strs, ncol=3, byrow=TRUE)
  colnames(strs) <- c("prefix", "body", "suffix")
  rownames(strs) <- names

  strs
} # splitByCommonTails()

Try the R.utils package in your browser

Any scripts or data that you put into this service are public.

R.utils documentation built on Nov. 18, 2023, 1:09 a.m.