【发布时间】:2017-01-23 04:29:36
【问题描述】:
我有两个 data.frames firstdf 和 secondf,(下面的示例数据。)我正在尝试创建一个函数,它可以输出类似于下面的 ExampleList 数据的结果。我想创建一个列表列表,它从 firstdf 中获取第一行条目并将它们的值放入 exampleList 中的事物和测试字段中,然后从 seconddf 中的 otherthing 字段中获取前 3 个值,将它们连接在一起,并保存它们在 exampleList 的 otherthing 字段中,然后移动到 firstdf 中的下一行和 seconddf 中的下 3 行。循环对我来说有点棘手,因此非常感谢您的提示。
data:
dput(firstdf)
structure(list(thing = structure(1:3, .Label = c("thing1", "thing2",
"thing3"), class = "factor"), test = structure(1:3, .Label = c("test1",
"test2", "test3"), class = "factor")), .Names = c("thing", "test"
), row.names = c(NA, -3L), class = "data.frame")
dput(seconddf)
structure(list(otherthing = structure(c(4L, 5L, 6L, 7L, 8L, 9L,
1L, 2L, 3L), .Label = c("thing10", "thing11", "thing12", "thing4",
"thing5", "thing6", "thing7", "thing8", "thing9"), class = "factor"),
other = structure(c(9L, 6L, 7L, 2L, 3L, 1L, 8L, 4L, 5L), .Label = c("fads",
"oiu", "qwer", "rewa", "rewq", "sfas", "sfwg", "tre", "xdfs"
), class = "factor")), .Names = c("otherthing", "other"), row.names = c(NA,
-9L), class = "data.frame")
然后输出:
dput(ExampleList)
list(structure(list(thing = "thing1", test = "test1", otherthing = c("thing4",
"thing5", "thing6")), .Names = c("thing", "test", "otherthing"
)), structure(list(thing = "thing2", test = "test2", otherthing = c("thing7",
"thing8", "thing9")), .Names = c("thing", "test", "otherthing"
)), structure(list(thing = "thing3", test = "test3", otherthing = c("thing10",
"thing11", "thing12")), .Names = c("thing", "test", "otherthing"
)))
[[1]]
[[1]]$thing
[1] "thing1"
[[1]]$test
[1] "test1"
[[1]]$otherthing
[1] "thing4" "thing5" "thing6"
[[2]]
[[2]]$thing
[1] "thing2"
[[2]]$test
[1] "test2"
[[2]]$otherthing
[1] "thing7" "thing8" "thing9"
[[3]]
[[3]]$thing
[1] "thing3"
[[3]]$test
[1] "test3"
[[3]]$otherthing
[1] "thing10" "thing11" "thing12"
【问题讨论】:
-
@akrun 我愿意将其视为重复,但我们需要一个更好的目标来解决这个问题
-
我说的是可能的,而不是肯定的