百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Java设置字符串的首字母为大写(java字符串首字母大写其他字母小写)

ztj100 2024-11-06 13:18 20 浏览 0 评论

概述

Java 标准库提供了 String.toUpperCase() 方法,它允许我们将字符串中的所有字母转换为大写。

在本文中,我们将学习如何将给定字符串的第一个字符仅转换为大写。

问题介绍

一个例子可以快速解释这个问题。 假设我们有一个字符串:

String input = "baby, I love you";

对于这个字符串,我们的预期结果是:

String result = "Baby, I love you";

如我们所见,我们只希望将第一个字符“b”更改为“B”。 但是,不应修改其余字符。当然,如果输入字符串为空,结果也应该是一个空字符串:

String input = "";
String result = "";

接下来,我们将介绍该问题的几种解决方案。 为简单起见,我们将使用单元测试断言来验证这几种解决方案是否能得到预期记过。

使用 substring() 方法

解决问题的第一个想法是将输入字符串拆分为两个子字符串。 例如,我们可以将 input 字符串拆分为“b”和“aby,I love you”。 换句话说,第一个子字符串只包含第一个字符,而另一个子字符串包含字符串的其余字符。

然后,我们可以对第一个子字符串应用 toUpperCase() 方法并连接第二个子字符串来解决问题。

Java 的 String 类的 substring() 方法可以帮助我们获取两个子字符串:

  • input.substring(0, 1) – 截取包含第一个字符的子字符串
  • input.substring(1) – 截取包含其余字符的子字符串

接下来,编写一个测试方法,看看该方案是否有效:

@Test
void testSubString(){
    String input = "baby, I love you";
    String result = "Baby, I love you";
    String output = input.substring(0, 1).toUpperCase() + input.substring(1);
    assertEquals(output, result);
}

运行测试,结果显示绿条通过:


但是,如果我们的输入是一个空字符串,这种方法会引发 IndexOutOfBoundsException。 这是因为当我们调用 input.substring(1) 时,结束索引 (1) 大于空字符串的长度 (0):

@Test
void testSubStringWithEmptString(){
    String EMPTY_INPUT = "";
    assertThrows(IndexOutOfBoundsException.class, () -> EMPTY_INPUT.substring(1));
}


此外,我们需要注意,如果输入字符串为NULL,这种方法将抛出 NullPointerException。

因此,在截取子字符串方法之前,我们需要检查并确保输入字符串不为NULL或字符串。

使用 Matcher.replaceAll() 方法

解决这个问题的另一个想法是使用正则表达式(“^.”)匹配第一个字符并将匹配的组转换为大写。

在 Java 9 之前这不是一件容易的事。这是因为 Matcher 的替换方法,例如 replaceAll() 和 replaceFirst(),不支持 Function 对象或 lambda 表达式替换器。 但是,这在 Java 9 中对此做了支持。

从 Java 9 开始,Matcher 的替换方法支持 Function 对象作为替换器。 也就是说,我们可以使用一个函数来处理匹配的字符序列并完成替换。 当然,要解决我们的问题,我们只需要在匹配的字符上调用 toUpperCase() 方法即可:

@Test
void testMathcher(){
    String input = "baby, I love you";
    String result = "Baby, I love you";
    String output = Pattern.compile("^.").matcher(input).replaceFirst(m -> m.group().toUpperCase());
    assertEquals(result, output);
}

执行单元测试,绿条通过:

如果正则表达式不匹配,则不会发生替换。 因此,此方案也适用于空输入字符串:

@Test
void testMathcherWithEmptyString(){
    String input = "";
    String result = "";
    String output = Pattern.compile("^.").matcher(input).replaceFirst(m -> m.group().toUpperCase());
    assertEquals(result, output);
}

另外,如果输入字符串为null,也会抛出 NullPointerException。 所以,在我们使用它之前,我们仍然需要做一个null检查。

使用 Apache Commons Lang 3 中的 StringUtils

Apache Commons Lang3 是一个很流行的库。 它提供了许多方便又实用的类并扩展了标准 Java 库的功能。

其中里面的StringUtils 类提供了 capitalize() 方法,直接解决了我们的问题。

要使用该库,我们首先在pom.xml添加 Maven 依赖:

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-lang3</artifactId>
    <version>3.12.0</version>
</dependency>

然后,跟之前一样,创建一个测试方法:

@Test
void testStringUtils(){
    String input = "baby, I love you";
    String result = "Baby, I love you";
    String output = StringUtils.capitalize(input);
    assertEquals(result, output);
}

跑下测试方法,绿条通过。 如我们所见,我们只是调用 StringUtils.capitalize(input), 然后里面自动帮我们做了功能实现

值得一提的是,StringUtils.capitalize() 方法是 null 安全的,并且也适用于字符串:

@Test
void testStringUtilsWithNull(){
    String emptyOutput = StringUtils.capitalize("");
    assertEquals("", emptyOutput);
    String nullOutput = StringUtils.capitalize(null);
    assertNull(nullOutput);
}

完结,谢谢点赞、评论和转发

相关推荐

Vue 技术栈(全家桶)(vue technology)

Vue技术栈(全家桶)尚硅谷前端研究院第1章:Vue核心Vue简介官网英文官网:https://vuejs.org/中文官网:https://cn.vuejs.org/...

vue 基础- nextTick 的使用场景(vue的nexttick这个方法有什么用)

前言《vue基础》系列是再次回炉vue记的笔记,除了官网那部分知识点外,还会加入自己的一些理解。(里面会有部分和官网相同的文案,有经验的同学择感兴趣的阅读)在开发时,是不是遇到过这样的场景,响应...

vue3 组件初始化流程(vue组件初始化顺序)

学习完成响应式系统后,咋们来看看vue3组件的初始化流程既然是看vue组件的初始化流程,咋们先来创建基本的代码,跑跑流程(在app.vue中写入以下内容,来跑流程)...

vue3优雅的设置element-plus的table自动滚动到底部

场景我是需要在table最后添加一行数据,然后把滚动条滚动到最后。查网上的解决方案都是读取html结构,暴力的去获取,虽能解决问题,但是不喜欢这种打补丁的解决方案,我想着官方应该有相关的定义,于是就去...

Vue3为什么推荐使用ref而不是reactive

为什么推荐使用ref而不是reactivereactive本身具有很大局限性导致使用过程需要额外注意,如果忽视这些问题将对开发造成不小的麻烦;ref更像是vue2时代optionapi的data的替...

9、echarts 在 vue 中怎么引用?(必会)

首先我们初始化一个vue项目,执行vueinitwebpackechart,接着我们进入初始化的项目下。安装echarts,npminstallecharts-S//或...

无所不能,将 Vue 渲染到嵌入式液晶屏

该文章转载自公众号@前端时刻,https://mp.weixin.qq.com/s/WDHW36zhfNFVFVv4jO2vrA前言...

vue-element-admin 增删改查(五)(vue-element-admin怎么用)

此篇幅比较长,涉及到的小知识点也比较多,一定要耐心看完,记住学东西没有耐心可不行!!!一、添加和修改注:添加和编辑用到了同一个组件,也就是此篇文章你能学会如何封装组件及引用组件;第二能学会async和...

最全的 Vue 面试题+详解答案(vue面试题知识点大全)

前言本文整理了...

基于 vue3.0 桌面端朋友圈/登录验证+60s倒计时

今天给大家分享的是Vue3聊天实例中的朋友圈的实现及登录验证和倒计时操作。先上效果图这个是最新开发的vue3.x网页端聊天项目中的朋友圈模块。用到了ElementPlus...

不来看看这些 VUE 的生命周期钩子函数?| 原力计划

作者|huangfuyk责编|王晓曼出品|CSDN博客VUE的生命周期钩子函数:就是指在一个组件从创建到销毁的过程自动执行的函数,包含组件的变化。可以分为:创建、挂载、更新、销毁四个模块...

Vue3.5正式上线,父传子props用法更丝滑简洁

前言Vue3.5在2024-09-03正式上线,目前在Vue官网显最新版本已经是Vue3.5,其中主要包含了几个小改动,我留意到日常最常用的改动就是props了,肯定是用Vue3的人必用的,所以针对性...

Vue 3 生命周期完整指南(vue生命周期及使用)

Vue2和Vue3中的生命周期钩子的工作方式非常相似,我们仍然可以访问相同的钩子,也希望将它们能用于相同的场景。...

救命!这 10 个 Vue3 技巧藏太深了!性能翻倍 + 摸鱼神器全揭秘

前端打工人集合!是不是经常遇到这些崩溃瞬间:Vue3项目越写越卡,组件通信像走迷宫,复杂逻辑写得脑壳疼?别慌!作为在一线摸爬滚打多年的老前端,今天直接甩出10个超实用的Vue3实战技巧,手把...

怎么在 vue 中使用 form 清除校验状态?

在Vue中使用表单验证时,经常需要清除表单的校验状态。下面我将介绍一些方法来清除表单的校验状态。1.使用this.$refs...

取消回复欢迎 发表评论: