in my table, some cells are vectors instead of single value, i.e. the column is a list instead of vector:
dt1 <- data.table(
colA= c('A1','A2','A3'),
colB=list('B1',c('B2a','B2b'),'B3'),
colC= c('C1','C2','C3'),
colD= c('D1','D2','D3')
)
dt1
# colA colB colC colD
#1: A1 B1 C1 D1
#2: A2 B2a,B2b C2 D2
#3: A3 B3 C3 D3
I need to reshape it to a long format unlisting that column colB
. So far I do it like this:
dt1[,.(colB=unlist(colB)),by=.(colA,colC,colD)]
# colA colC colD colB
#1: A1 C1 D1 B1
#2: A2 C2 D2 B2a
#3: A2 C2 D2 B2b
#4: A3 C3 D3 B3
it does the job but I don't like that I have to indicate all other column names explicitly in by=
. Is there better way to do this?
(I'm sure it's already answered elsewhere but I couldn't find it so far)
P.S. ideally I would like to manage without any external packages
See Question&Answers more detail:os