我有一个数据框,其中包含一个列,我想在其中放置多个值(每个记录可以有不同的值)。
我正在尝试使用for循环将数据附加到它,但它不断给出错误:
Error in `[<-.data.frame`(`*tmp*`, 1, "piet", value = c(1, 2)) :
replacement has 2 rows, data has 1
是否无法覆盖/附加到此列? 小例子代码:
a = data.frame(piet=numeric())
a[1,'piet'] = c(1)
a[1,'piet'] = c(1,2) # this throws the error
我意识到有比使用for循环更好的方法,但是我的数据在多个.csv文件中有些随机分布(其中一些文件有重叠的记录,我试图在这里结合其结果)。
答案 0 :(得分:0)
好的,这真的很奇怪,但它可以使用list(c())
(感谢@Frank)和非常具体的编码格式:
a = data.frame(piet=list()) #initialize data frame
a[1,'piet'] = '' # create first row
a$piet[c(T)] = list(c(1,2,3)) # overwrite with list
a$piet[c(T)] = list(c(4,5,6)) # overwrite with new list
a$piet[c(T)] = list(c(unlist(a[1,'piet']),8,9)) # append to existing list
a:
的最终内容> a
piet
1 4, 5, 6, 8, 9
请注意,a$piet[row selection]
是强制性的,并且使用list(c())
!