在R中试图编写一个函数,该函数使用单词MarsuPial,并产生MarsuPial。
当前代码
mycap <- function(mystr = "") {
mystr <- tolower(mystr)
a <- substr(mystr, 1, 1)
b <- substr(mystr, 2, nchar(mystr))
paste(tolower(a), b, sep = "")
}
您可以使用substr<-
将最后一个字符大写。
mycap <- function(mystr = "") {
mystr <- tolower(mystr)
n <- nchar(mystr)
substr(mystr, n, n) <- toupper(substr(mystr, n, n))
return(mystr)
}
mycap('MarsuPial')
#[1] "marsupiaL"
mycap('dummy')
#[1] "dummY"
mycap <- function(mystr = "") {
# a: the string without the last character
a <- substr(mystr, 1, nchar(mystr)-1)
# b: only the last character
b <- substr(mystr, nchar(mystr), nchar(mystr))
# lower(a) and upper(b)
paste(tolower(a), toupper(b), sep = "")
}
例如:
mycap("MarsuPial")
[1] "marsupiaL
另一个避免字符串子集化/拆分的选项是将字符串转换为整数向量以反转顺序,这样我们就可以使用stringr::str_to_title
。
library(stringr)
library(dplyr)
mycap <- function(mystr = "") {
mystr %>% utf8ToInt %>% rev %>% intToUtf8 %>% str_to_title %>% utf8ToInt %>% rev %>% intToUtf8
}
mycap("MarsuPial")
#[1] "marsupiaL"
mycap("dummy")
#[1] "dummY"
或者另一个快速选项是使用stringi::stri_reverse
和stringi::stri_trans_totitle
library(stringi)
mycap <- function(mystr = "") stri_reverse(stri_trans_totitle(stri_reverse(mystr)))