mam kod, R, który wykonuje pewną operację uzyskiwania danych o wszystkich plikach w katalogu bieżącym zastosowaniem kodu:Wyodrębnianie wyjść z lapply do dataframe
files <- list.files(".", pattern="*.tts")
results <- lapply(files, data_for_time, "17/06/2006 12:00:00")
Wyjście z lapply jest następujący (wyodrębnione stosując dput()
) - w zasadzie lista pełna wektorów:
list(c("amer", "14.5"), c("appl", "14.2"), c("brec", "13.1"),
c("camb", "13.5"), c("camo", "30.1"), c("cari", "13.8"),
c("chio", "21.1"), c("dung", "9.4"), c("east", "11.8"), c("exmo",
"12.1"), c("farb", "14.7"), c("hard", "15.6"), c("herm",
"24.3"), c("hero", "13.3"), c("hert", "11.8"), c("hung",
"26"), c("lizr", "14"), c("maid", "30.4"), c("mart", "8.8"
), c("newb", "14.7"), c("newl", "14.3"), c("oxfr", "13.9"
), c("padt", "10.3"), c("pbil", "13.6"), c("pmtg", "11.1"
), c("pmth", "11.7"), c("pool", "14.6"), c("prae", "11.9"
), c("ral2", "12.2"), c("sano", "15.3"), c("scil", "36.2"
), c("sham", "12.9"), c("stra", "30.9"), c("stro", "14.7"
), c("taut", "13.7"), c("tedd", "22.3"), c("wari", "12.7"
), c("weiw", "13.6"), c("weyb", "8.4"))
jednak chciałbym wtedy do czynienia z tego wyjścia jako dataframe z dwóch kolumn: jeden dla kodu alfabetycznego ("amer"
, "appl"
etc) oraz jeden dla t on numer (14.5
, 14.2
itp.).
Niestety, as.data.frame
wydaje się nie działać z tym wejściem zagnieżdżonych wektorów wewnątrz listy. Jak mam to zmienić? Czy muszę zmienić sposób, w jaki moja funkcja data_for_time
zwraca swoje wartości? W tej chwili po prostu zwraca c(name, value)
. Czy istnieje dobry sposób konwertowania z tego rodzaju danych wyjściowych na ramkę danych?
Jeśli użył 'sapply' zamiast' lapply' mogłeś zdobyć więcej „zwykłej” obiektu. –