我们可以使用正则表达式的外观来区分字母和数字
v1 <- strsplit(str1, "(?<=[A-Za-z])(?=[0-9])|(?<=[0-9])(?=[A-Za-z])", perl = TRUE)[[1]]
v1[c(TRUE, FALSE)]
#[1] "A" "B" "C"
as.numeric(v1[c(FALSE, TRUE)])
#[1] 1 10 5
Run Code Online (Sandbox Code Playgroud)
str1 <- "A1B10C5"
Run Code Online (Sandbox Code Playgroud)
str_extract_all 是另一种方法:
library(stringr)
> str <- "A1B10C5"
> str
[1] "A1B10C5"
> str_extract_all(str, "[0-9]+")
[[1]]
[1] "1" "10" "5"
> str_extract_all(str, "[aA-zZ]+")
[[1]]
[1] "A" "B" "C"
Run Code Online (Sandbox Code Playgroud)