我有与here相同的问题,除了我想用另一个向量指定变量分割长度。所以,像这样:
example.data<-paste("ex",1:10,sep="")
example.data
[1] "ex1" "ex2" "ex3" "ex4" "ex5" "ex6" "ex7" "ex8" "ex9" "ex10"
split.lens <- c(4,2,1,3)
应该给我以下列表:
result.list
[[1]]
[1] "ex1" "ex2" "ex3" "ex4"
[[2]]
[1] "ex5" "ex6"
[[3]]
[1] "ex7"
[[4]]
[1] "ex8" "ex9" "ex10"
我无法找出使用split
执行此操作的最佳方法。有什么想法吗?
谢谢!
答案 0 :(得分:10)
split(example.data, rep(1:4, c(4,2,1,3)))
答案 1 :(得分:3)
我在qdapTools的开发版本中添加了一种更通用的方法,以便在特定位置拆分各种数据类型。这是方法:
## install qdapTools
devtools::install_github("trinker/qdapTools")
library(qdapTools)
loc_split(example.data, head(cumsum(split.lens) + 1, -1))
## [[1]]
## [1] "ex1" "ex2" "ex3" "ex4"
##
## [[2]]
## [1] "ex5" "ex6"
##
## [[3]]
## [1] "ex7"
##
## [[4]]
## [1] "ex8" "ex9" "ex10"
该函数在应用于向量时基本上包含类似于@ RStudent答案的代码。