inst/prototype/GEO.r

get_gse <- function(gseID) {
    gsecat <- sub("\\d{3}$", "nnn", gseID)
    gsesoft <- sprintf("%s_family.soft.gz", gseID)
    url <- sprintf("https://ftp.ncbi.nlm.nih.gov/geo/series/%s/%s/soft/%s", gsecat, gseID, gsesoft)
    yulab.utils:::mydownload(url, destfile = gsesoft)
    GEOquery::getGEO(filename = gsesoft)
}

get_gsm <- function(gse, item = "supplementary_file_1") {
    lapply(GEOquery::GSMList(gse), function(x) x@header[item])
}




download_gsm <- function(gsm) {
    for (x in gsm) {
        destfile <- sub(".*/([^/]+)$", "\\1", x)
        yulab.utils:::mydownload(x, destfile = destfile)
    }
}

gseID <- "GSE123904"

gse <- get_gse(gseID)

gsm <- get_gsm(gse)

get_gsm(gse, 'extract_protocol_ch1') |> head(2)

download_gsm(gsm)
YuLab-SMU/yulab.utils documentation built on April 14, 2025, 1:54 p.m.