кадров R данных и списки R потенциально несовместимы ...
список является, по существу, вектор, в котором каждый элемент может быть различного типа и длины элементов. Между тем, кадр данных можно рассматривать как единую электронную таблицу, где каждый столбец может хранить данные другого типа или незавершенные списки , где каждый элемент имеет одинаковую длину. Этот последний момент важен, поскольку списки могут иметь неравные длины, а кадры данных - нет.
Таким образом, это может быть проще, чтобы сохранить список как файл RDS с помощью saveRDS()
dataDir <- "."
saveRDS(operacions, file.path(dataDir, "files"))
operacions2 <- readRDS(file.path(dataDir, "files"))
это сохранит его в качестве R-объекта, а так же, восстановить объект R позже.
Если вы хотите конвертировать в кадр данных, вы можете сначала преобразовать во вложенный фрейм данных, а затем заполнить пробелы в кадре данных. Таким образом, ...
require(data.table)
require(plyr)
operacions<-list(list(Nom="Victor",Bolis= c("Negro","azul","verde")),list(Nom="Dani",Lapices=c(1:4)))
str(operacions)
operacionsdf <- lapply(operacions, data.frame, stringsAsFactors = FALSE)
str(operacionsdf)
operacionsdf2 <- rbind.fill(operacionsdf)
str(operacionsdf2)
write.csv2(operacionsdf2, "file.csv",row.names = FALSE)
operacionsdf3 <- read.csv2("file.csv")
str(operacionsdf3)
выход:
> require(data.table)
> require(plyr)
> operacions<-list(list(Nom="Victor",Bolis= c("Negro","azul","verde")),list(Nom="Dani",Lapices=c(1:4)))
> str(operacions)
List of 2
$ :List of 2
..$ Nom : chr "Victor"
..$ Bolis: chr [1:3] "Negro" "azul" "verde"
$ :List of 2
..$ Nom : chr "Dani"
..$ Lapices: int [1:4] 1 2 3 4
> operacionsdf <- lapply(operacions, data.frame, stringsAsFactors = FALSE)
> str(operacionsdf)
List of 2
$ :'data.frame': 3 obs. of 2 variables:
..$ Nom : chr [1:3] "Victor" "Victor" "Victor"
..$ Bolis: chr [1:3] "Negro" "azul" "verde"
$ :'data.frame': 4 obs. of 2 variables:
..$ Nom : chr [1:4] "Dani" "Dani" "Dani" "Dani"
..$ Lapices: int [1:4] 1 2 3 4
> operacionsdf2 <- rbind.fill(operacionsdf)
> str(operacionsdf2)
'data.frame': 7 obs. of 3 variables:
$ Nom : chr "Victor" "Victor" "Victor" "Dani" ...
$ Bolis : chr "Negro" "azul" "verde" NA ...
$ Lapices: int NA NA NA 1 2 3 4
> write.csv2(operacionsdf2, "file.csv",row.names = FALSE)
> operacionsdf3 <- read.csv2("file.csv")
> str(operacionsdf3)
'data.frame': 7 obs. of 3 variables:
$ Nom : Factor w/ 2 levels "Dani","Victor": 2 2 2 1 1 1 1
$ Bolis : Factor w/ 3 levels "azul","Negro",..: 2 1 3 NA NA NA NA
$ Lapices: int NA NA NA 1 2 3 4
Это не кадр данных, это список списков. Проблема здесь в том, что элементы имеют разные длины. 'Rapply (operacions, length)' возвращает '1 3 1 4'. Это проблема, потому что '.csv' требует фиксированной длины. Каким будет ожидаемый формат вывода? – Laterow
Это может ответить на ваш вопрос: http://stackoverflow.com/a/27594769/5805670 – Laterow