Чтение заголовка EDF
У меня более 100 файлов EEG EDF. Я хочу извлечь время и дату начала вместе с продолжительностью записи во фрейм данных. Есть ли простой способ извлечь эти данные? Предпочтительно в R или Matlab.
Я успешно извлек данные, используя:
library(edfReader)
CHdr <- readEdfHeader("E:/data/EDF/Rtest/EEG1 (2).edf")
summary(CHdr)
format (CHdr$startTime, format="%Y-%m-%d %H:%M:%S", usetz = FALSE)
CHdr$recordedPeriod
Но делать это для более чем 100 файлов EDF может быть немного утомительно...
2 ответа
Вы можете использовать lapply
с readEdfHeader
чтобы собрать все заголовки в одной строке кода.
Во-первых, рабочий пример с наборами данных пакета.
old_dir <- getwd()
libDir <- system.file("extdata", package = 'edfReader')
setwd(libDir)
Получить .edf
имена файлов и прочтите их заголовки.
fls <- list.files(pattern = '\\.edf')
edf_headers <- lapply(fls, readEdfHeader)
Затем извлеките соответствующую информацию и rbind
это для создания data.frame.
res <- lapply(edf_headers, function(x){
startTime <- x[['startTime']]
startDate <- substr(x[['recordingId']], 11, 21)
recordDuration <- x[['recordDuration']]
data.frame(startTime, startDate, recordDuration)
})
res <- do.call(rbind, res)
res
# startTime startDate recordDuration
#1 2000-01-01 14:15:16 01-JAN-2000 0.1
#2 2009-12-10 12:44:02 10-DEC-2009 1.0
#3 2009-12-10 12:44:02 10-DEC-2009 1.0
Сбросить рабочий каталог.
setwd(old_dir)
Трудно ответить без воспроизводимого примера, но я бы предложил перебрать ваши файлы в цикле, хотя может быть более элегантный способ реализовать все это в меньшем количестве строк с помощью приложения. При условии, что все они находятся в одном каталоге, это возможно при следующих условиях:
library(edfReader)
files <- list.files("E:/data/EDF/Rtest/", pattern = "*.edf")
outputs <- list()
for (i in 1:length(files)) {
i_file <- paste0("E:/data/EDF/Rtest/",files[i])
i_CHdr <- readEdfHeader(i_file)
#whatever else you are doing
outputs[[i]] <- output_from_your_code
rm(i_file, i_CHdr) #plus whatever objects your code has
}
#work with outputs list as necessary; dplyr::bind_rows is often helpful