R/doc.R

Defines functions dataMerge doc2data

Documented in dataMerge doc2data

#' Merge two 'data' files
#' @param
#' @keywords
#' @export
#' @examples
#' dataMerge()

dataMerge <- function(data_1, data_2) {
  if (!grepl("chr", data1[1, 1])) {
    data1$chr <- paste0("chr", data1$chr)
  }
  if (!grepl("chr", data2[1, 1])) {
    data2$chr <- paste0("chr", data2$chr)
  }
  data <- merge(data1, data2, all = TRUE, sort = FALSE)
  data$chr <- factor(data$chr, levels = paste0("chr", c(1:22, "X", "Y")))
  data <- data[order(data$chr, data$start), ]
  data$chr <- as.character(data$chr)
  return(data)
}


#' Using 'doc' files to make the 'data' file
#' @param
#' @keywords
#' @export
#' @examples
#' doc2data()

doc2data <- function(doc.list, write.file.path = NULL) {
  # 'doc.list' is a character vector
  require(data.table)
  for (i in seq_along(doc.list)) {
    message("Processing ", i, ": ", doc.list[i])
    doc_file <- fread(doc.list[i], stringsAsFactors = FALSE, data.table = FALSE)
    sample_name <- gsub('.5k.doc', '', basename(doc.list[i]))
    doc_file <- doc_file[, c(1:3, 6)]
    colnames(doc_file) <- c("chr", "start", "end", sample_name)
    if (i == 1) {
      data_file <- doc_file
    } else {
      data_file <- merge(data_file, doc_file, all = TRUE, sort = FALSE)
    }
  }
  if (!grepl("chr", data_file[1, 1])) {
    data_file$chr <- paste0("chr", data_file$chr)
  }
  data_file$chr <- factor(data_file$chr, levels = paste0("chr", c(1:22, "X", "Y")))
  data_file <- data_file[order(data_file$chr, data_file$start), ]
  data_file$chr <- as.character(data_file$chr)
  if (is.null(write.file.path)) {
    return(data_file)
  } else {
    write.table(data_file, file = file.path(write.file.path, "reads.5k.data"), quote = FALSE, col.names = TRUE, row.names = FALSE, sep = "\t")
  }
}
hutaobo/AluScanCNV2 documentation built on May 27, 2019, 3:31 p.m.