-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathfetch_data.R
35 lines (27 loc) · 909 Bytes
/
fetch_data.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# download GEO data
.libPaths("~/KP/RShiny/packages/")
library(GEOquery)
library(xml2)
library(R.utils)
#open file with gse_accessions.txt
con = file("gse_accessions_filtered.txt", "r")
while ( TRUE ) {
line = readLines(con, n=1)
if ( length(line) == 0 ) {
break
}
print(line)
geo_id <- toupper(line)
if(file.exists(paste0("~/KP/RShiny/GEOdata/",geo_id) )){
print("Directory exists!") # repetitive GSE ID; skip to next one
}
else {
dir.create(file.path("~/KP/RShiny/GEOdata/", geo_id)) # create directory
gse <- getGEO(geo_id, GSEMatrix=TRUE, destdir = paste0("~/KP/RShiny/GEOdata/",geo_id) )
# fetching supplimental files
getGEOSuppFiles(geo_id, makeDirectory = TRUE, baseDir = paste0("~/KP/RShiny/GEOdata/",geo_id),
fetch_files = TRUE, filter_regex = NULL)
print(paste0("Supplimental Data download finished for ",geo_id))
}
}
close(con)