拆分R中的数字

dpl*_*net 6 r

R我有一个号码,比方说1293828893,叫x.

我希望拆分这个数字,以便删除中间4位数3828并返回它们,伪代码如下:

splitnum <- function(number){
     #check number is 10 digits
     if(nchar(number) != 10){
          stop("number not of right size");
     }
     middlebits <- middle 4 digits of number
     return(middlebits);
}
Run Code Online (Sandbox Code Playgroud)

这是一个非常简单的问题,但我发现的唯一解决方案适用于字符串,而不是数字字符串.

如果有兴趣,我试图R中间方法创建一个实现,但这一步特别棘手.

Rei*_*son 9

你可以用substr().请参阅其帮助页面?substr.在你的函数中我会这样做:

splitnum <- function(number){
    #check number is 10 digits
    stopifnot(nchar(number) == 10)
    as.numeric(substr(number, start = 4, stop = 7))
}
Run Code Online (Sandbox Code Playgroud)

这使:

> splitnum(1293828893)
[1] 3828
Run Code Online (Sandbox Code Playgroud)

删除as.numeric(....)您想要数字作为字符串的最后一行的包装.


Jos*_*ich 8

只需使用整数除法:

> x <- 1293828893
> (x %/% 1e3) %% 1e4
[1] 3828
Run Code Online (Sandbox Code Playgroud)


Jos*_*ien 6

这是一个完全避免将数字转换为字符的函数

splitnum <- function(number){
     #check number is 10 digits
     if(trunc(log10(X))!=9) {
          stop("number not of right size")
     }
     (number %/% 1e3) %% 1e4
}

splitnum(1293828893)
# [1] 3828
Run Code Online (Sandbox Code Playgroud)