为了账号安全,请及时绑定邮箱和手机立即绑定

将两个单词的第一个字母大写为两个单词的字符串

将两个单词的第一个字母大写为两个单词的字符串

侃侃尔雅 2019-08-16 16:11:00
将两个单词的第一个字母大写为两个单词的字符串假设我有一个两个单词的字符串,我想把它们都大写。name <- c("zip code", "state", "final count")这个Hmisc包有一个capitalize大写第一个单词的函数,但我不确定如何将第二个单词大写。帮助页面capitalize并不表示它可以执行该任务。library(Hmisc)capitalize(name)# [1] "Zip code"    "State"       "Final count"我想得到:c("Zip Code", "State", "Final Count")三字串怎么样:name2 <- c("I like pizza")
查看完整描述

3 回答

?
江户川乱折腾

TA贡献1851条经验 获得超5个赞

执行大写的基本R函数是toupper(x)。从帮助文件中可以找到?toupper您需要的功能:

simpleCap <- function(x) {
  s <- strsplit(x, " ")[[1]]
  paste(toupper(substring(s, 1,1)), substring(s, 2),
      sep="", collapse=" ")}name <- c("zip code", "state", "final count")sapply(name, simpleCap)

     zip code         state   final count 
   "Zip Code"       "State" "Final Count"

编辑适用于任何字符串,无论字数如何:

simpleCap("I like pizza a lot")[1] "I Like Pizza A Lot"


查看完整回答
反对 回复 2019-08-16
?
偶然的你

TA贡献1841条经验 获得超3个赞

匹配从开头^或开头后开始的正则表达式,[[:space:]]后面跟一个字母字符[[:alpha:]]。全局(gsub中的g)用匹配的开头或空格以及匹配的字母字符的大写版本替换所有这些出现\\1\\U\\2。这必须使用perl风格的正则表达式匹配来完成。

gsub("(^|[[:space:]])([[:alpha:]])", "\\1\\U\\2", name, perl=TRUE)# [1] "Zip Code"    "State"       "Final Count"

在替换参数的更多细节中gsub()\\1说'使用x匹配第一个子表达式的部分',即x匹配的部分(^|[[:spacde:]])。同样,\\2说使用x匹配第二个子表达式的部分([[:alpha:]])。的\\U是使用支持语法perl=TRUE和手段,使下一个字符大写。因此对于“邮政编码”,\\1是“Zip”,\\2是“代码”,\\U\\2是“代码”,并且\\1\\U\\2是“邮政编码”。

?regexp页面有助于理解正则表达式,?gsub将事物放在一起。


查看完整回答
反对 回复 2019-08-16
  • 3 回答
  • 0 关注
  • 631 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信