R/write_ipa.R

Defines functions write_ipa

Documented in write_ipa

#' Write DESeq results to text files for bulk uploading into IPA
#'
#' @param result_all a list from \code{results_all}
#' @param run add run ID to file name
#' @param homolog use human homolog as ID
#'
#' @return Text files
#'
#' @author Chris Stubben
#'
#' @examples
#' \dontrun{
#'  write_ipa(res)
#' }
#' @export

write_ipa <- function(result_all, run, homolog=FALSE){

   ##  if results are a tibble (since simplify=TRUE by default)
   if(!class(result_all)[1] == "list"){
         n <- attr(result_all, "contrast")
         result_all <- list(result_all)
         names(result_all) <- n
   }
   res <- result_all
   names(res)  <- gsub( "/", "", names(res))
if(!missing(run)) names(res)  <- paste(run, names(res))

   for (i in 1:length(res)){
      # name output file
      vs <- gsub( "\\.* ", "_", names(res[i]))
      vs <- gsub("_+_", "_", vs, fixed=TRUE)
      vs <- paste0(vs, ".txt")
      message( "Saving ",  vs)
      if(homolog){
          z <- dplyr::filter( res[[i]], human_homolog != "")  %>%
          dplyr::select(human_homolog, baseMean, log2FoldChange, padj) %>%
          dplyr::rename(human_homolog="id")
      }else{
          z <- dplyr::select(res[[i]], id, baseMean, log2FoldChange, padj)
      }
      readr::write_tsv(z, vs)
   }
}
HuntsmanCancerInstitute/hciR documentation built on Dec. 10, 2024, 12:22 p.m.