查找向量中元素之间的序列

时间:2017-04-04 15:38:59

标签: r

我想获得向量中元素之间的序列。这是一个可重复的例子。

vec <- c( 'a', letters[2:7], 'a', letters[9:14], 'a', letters[16:21] ) # sample data
ind_a <- which( grepl( 'a', vec ))  # indices matching the character 'a'
ind_a <- c( ind_a, length(vec)+1 )  # concatenate the length of 'vec' + 1 with indices
ind_a
# [1]  1  8 15 22

现在,如何计算ind_a元素之间的序列。例如,seq(from = 2, to = 7, by = 1)和其他人一样。

最好,我想知道基础R中的任何功能。

预期输出

# List of 3
# $ : int [1:6] 2 3 4 5 6 7
# $ : int [1:6] 9 10 11 12 13 14
# $ : int [1:6] 16 17 18 19 20 21

2 个答案:

答案 0 :(得分:4)

我们通过删除最后和第一个观察结果从'ind_a'创建两个向量,然后使用Map

获取相应元素的序列
Map(seq, ind_a[-length(ind_a)]+1, ind_a[-1]-1)
#[[1]]
#[1] 2 3 4 5 6 7

#[[2]]
#[1]  9 10 11 12 13 14

#[[3]]
#[1] 16 17 18 19 20 21

或者@ Zelazny7建议,删除第一个和最后一个元素可以使用headtail函数

完成
Map(`:`, head(ind_a, -1) + 1, tail(ind_a, -1) - 1)

答案 1 :(得分:2)

lapply(2:length(ind_a), function(i) setdiff(sequence(ind_a[i] - 1), sequence(ind_a[i-1])))
#OR    
lapply(2:length(ind_a), function(i) (ind_a[i-1]+1):(ind_a[i]-1))

#[[1]]
#[1] 2 3 4 5 6 7

#[[2]]
#[1]  9 10 11 12 13 14

#[[3]]
#[1] 16 17 18 19 20 21