关于如何提取向量的每个第n个元素有很多问题,但是我找不到如何在向量的每个第n个元素之后轻松添加值的问题。有没有一种简单的方法可以在向量中的每个第n个元素之后添加某个值?
例如,假设我们有两个向量:
v1 <- paste0(letters[1:3], rep(1:5, each = 3))
> v1
[1] "a1" "b1" "c1" "a2" "b2" "c2" "a3" "b3" "c3" "a4" "b4" "c4" "a5" "b5" "c5"
v2 <- paste0("header", seq(1:5))
> v2
[1] "header1" "header2" "header3" "header4" "header5"
现在我想在v2
的每个第三个元素之后添加v1
的元素,从第一个元素开始。结果应如下所示:
[1] "header1" "a1" "b1" "c1" "header2" "a2" "b2" "c2" "header3" "a3" "b3" "c3" "header4" "a4" "b4" "c4" "header5" "a5" "b5" "c5"
答案 0 :(得分:8)
您可以将长矢量放入具有适当尺寸的矩阵中;将标题贴在上面;然后使用c()
将矩阵展平为矢量。
构造示例:
v1 <- paste0(letters[1:3], rep(1:5, each = 3))
v2 <- paste0("header", seq(1:5))
制作矩阵并附上标题:
r <- rbind(v2,matrix(v1,ncol=length(v2)))
## "header1" "header2" "header3" "header4" "header5"
## "a1" "a2" "a3" "a4" "a5"
## "b1" "b2" "b3" "b4" "b5"
## "c1" "c2" "c3" "c4" "c5"
现在压扁它:
c(r)
答案 1 :(得分:6)
我们可以使用分组变量(使用split
创建)%/%
'v1'来形成list
,然后连接(c
)相应的元素' v2'与list
使用Map
和unlist
。
unlist(Map(`c`, v2, split(v1, (seq_along(v1)-1)%/%3+1)), use.names=FALSE)
#[1] "header1" "a1" "b1" "c1" "header2" "a2" "b2"
#[8] "c2" "header3" "a3" "b3" "c3" "header4" "a4"
#[15] "b4" "c4" "header5" "a5" "b5" "c5"
如果'v1'的长度是'3'的倍数,我们可以创建matrix
'v1',cbind
'v2',转置输出并转换{{ 1}} matrix
与vector
。
c