![](/img/trans.png)
[英]replacing specific positional value in each matrix within a list, with sequential values from a vector in r
[英]R - Produce a string that summarizes a vector of integers by replacing sequential values with the start and end value of the sequence
我正在尋找一種有效的方法來簡化整數向量作為匯總字符串,以便將其格式化為適合表格單元格。
例如:
c(1, 2, 3, 4, 6, 8, 9, 10)
應該產生
"1-4, 6, 8-10"
這在打印向量中的所有元素將很快使表格不可讀的情況下尤其有用。
例如
c(1:50, 53, 89:120)
應該產生
"1-50, 53, 89-120"
您希望將元素分組為連續整數的塊。 diff
可以告訴你兩個連續元素是否在同一個塊中, cumsum
可以對塊進行編號, tapply
可以提取每個塊的第一個和最后一個元素。
x <- c(1:50, 53, 89:120)
y <- tapply( x, c(0,cumsum(diff(x) != 1)), range )
# Format the result
y <- sapply(y, function(u)
if(u[1]==u[2]) u[1]
else paste(u,collapse=":")
)
paste(y, collapse=", ")
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.