我有以下字符串:“1,34:36,52:58,22:28,82:88,101:102,104:153,120:254,315:368,489:nrow(df)”
。是否有某种方法使用此字符串来提取与字符串中的数字相对应的数据帧 (df
) 的行。
我尝试过使用 eval
和 get
的组合,但这些不起作用,并且怀疑它们是否是正确的路线。
示例数据框:
df <- as.data.frame( matrix(rnorm(5000), nrow=500,ncol=10) )
最佳答案
您可以结合使用eval
和parse
:
df <- as.data.frame( matrix(rnorm(5000), nrow=500,ncol=10) )
a <- "1,34:36,52:58,22:28,82:88,101:102,104:153,120:254,315:368,489:nrow(df)"
index <- unlist(lapply(strsplit(a, ",")[[1]], function(x)eval(parse(text=x))))
index
# [1] 1 34 35 36 52 53 54 ...
#[253] .... 494 495 496 497 498 499 500
关于r - 如何使用索引字符串从 R 中的数据帧或矩阵中提取行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18871147/