str_pad z stringr:
library(stringr)
pad_if = function(x, cond, n, fill = "0") str_pad(x, n*cond, pad = fill)
s = str_split_fixed(names,"(?=\\d)",2)
# [,1] [,2]
# [1,] "apple" ""
# [2,] "banana" ""
# [3,] "orange" ""
# [4,] "apple" "1"
# [5,] "apple" "2"
# [6,] "apple" "10"
# [7,] "apple" "11"
# [8,] "banana" "2"
# [9,] "banana" "12"
paste0(s[,1], pad_if(s[,2], cond = nchar(s[,2]) > 0, n = max(nchar(s[,2]))))
# [1] "apple" "banana" "orange" "apple01" "apple02" "apple10" "apple11" "banana02" "banana12"
ta rozciąga się również do przypadków, jak będzie z c("a","a2","a20","a202")
do c("a","a002","a020","a202")
, których inne metody nie obejmują.
Pakiet stringr oparty jest na stringi, który ma tę samą funkcjonalność, co tutaj, zgaduję.
sprintf od podstawy, W podobny sposób:
pad_if2 = function(x, cond, n, fill = "0")
replace(x, cond, sprintf(paste0("%",fill,n,"d"), as.numeric(x)[cond]))
s0 = strsplit(names,"(?<=\\D)(?=\\d)|$",perl=TRUE)
s1 = sapply(s0,`[`,1)
s2 = sapply(sapply(s0,`[`,-1), paste0, "")
paste0(s1, pad_if2(s2, cond = nchar(s2) > 0, n = max(nchar(s2))))
pad_if2
mniej ogólne zastosowanie niż pad_if
, ponieważ wymaga x
być coercible numerycznego. Prawie każdy krok tutaj jest bardziej zwarty niż odpowiedni kod z wyżej wymienionymi pakietami.
Czy 'sub (" ([a-z]) ([0-9]) $ "," \\ 10 \\ 2 ", nazwy)' pomóc? – etienne
@etienne yes! Czy możesz wyjaśnić konstrukcję "\\ 10 \\ 2" dla wymiany? – ano
Dodałem odpowiedź z wyjaśnieniem. – etienne