У меня есть список списков со следующей структурой:
a = list("t" = list('abc'), "c" = list('def','ghi'))
b = list("t" = list('jk','kl'), "c" = list('lmn'))
c = list("t" = list('op','pq','z'), "c" = list('qrs','tuv','wxy'))
ls = list('one'=a,'two'=b,'three'=c)
Мне нужно сохранить это в текстовом файле.Поскольку не все элементы имеют одинаковую длину, мне нужно заполнить nans, прежде чем превратить его в кадр данных и записать в файл.Мне нужен файл, который выглядит примерно так (здесь он показан примерно как .csv, но хорошо подходит .txt):
t1, t2, t3, c1, c2, c3
one,abc,nan,nan,def,ghi,nan
two,jk,kl,nan,lmn,nan,nan
three,op,pq,z,qrs,tuv,wxy
Я новичок в R, поэтому у меня есть только общее представление о том, как я могусделать это и не могу понять синтаксис.Примерно так в псевдокоде:
lapply(ls, fill nans)
lapply(ls, unlist)
lapply(ls, names=[t1,t2,t3,c1,c2,c3])
df=data.frame(ls)
write.table(df)
Может ли кто-нибудь провести меня через это?
Редактировать: я смог добиться некоторого прогресса с:
ellength <- function(ls,i) {return(length(ls[[i]]))}
fillna <- function(ls,i,m) {
if (length(ls[[i]])<m) {
return(append(ls[[i]],vector('list',length=m-length(ls[[i]]))))
}
else {return(ls[[i]])}
}
make_col <- function(ls,i){
return(lapply(ls,fillna,i=i,m=max(unlist(lapply(ls,ellength,i=i)))))
}
> matrix(list(make_col(ls,'t'),make_col(ls,'c')))
[,1]
[1,] List,3
[2,] List,3
Но ядо сих пор не могу записать это в файл каким-либо связным способом.Это так просто сделать в Python;Я должен что-то упустить.Помощь