java中驼峰命名和下划线命名互转方法(代码实现)

简介: 1 /** 2 * 将驼峰式命名的字符串转换为下划线大写方式。如果转换前的驼峰式命名的字符串为空,则返回空字符串。 3 * 例如:HelloWorld->HELLO_WORLD 4 * @param name 转换前的驼峰式命名的字符串 5 * @return 转换后下划线大写方...
 1 /**
 2  * 将驼峰式命名的字符串转换为下划线大写方式。如果转换前的驼峰式命名的字符串为空,则返回空字符串。
 3  * 例如:HelloWorld->HELLO_WORLD
 4  * @param name 转换前的驼峰式命名的字符串
 5  * @return 转换后下划线大写方式命名的字符串
 6  */
 7 public static String underscoreName(String name) {
 8     StringBuilder result = new StringBuilder();
 9     if (name != null && name.length() > 0) {
10         // 将第一个字符处理成大写
11         result.append(name.substring(0, 1).toUpperCase());
12         // 循环处理其余字符
13         for (int i = 1; i < name.length(); i++) {
14             String s = name.substring(i, i + 1);
15             // 在大写字母前添加下划线
16             if (s.equals(s.toUpperCase()) && !Character.isDigit(s.charAt(0))) {
17                 result.append("_");
18             }
19             // 其他字符直接转成大写
20             result.append(s.toUpperCase());
21         }
22     }
23     return result.toString();
24 }
 1 /**
 2  * 将下划线大写方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。
 3  * 例如:HELLO_WORLD->HelloWorld
 4  * @param name 转换前的下划线大写方式命名的字符串
 5  * @return 转换后的驼峰式命名的字符串
 6  */
 7 public static String camelName(String name) {
 8     StringBuilder result = new StringBuilder();
 9     // 快速检查
10     if (name == null || name.isEmpty()) {
11         // 没必要转换
12         return "";
13     } else if (!name.contains("_")) {
14         // 不含下划线,仅将首字母小写
15         return name.substring(0, 1).toLowerCase() + name.substring(1);
16     }
17     // 用下划线将原始字符串分割
18     String camels[] = name.split("_");
19     for (String camel :  camels) {
20         // 跳过原始字符串中开头、结尾的下换线或双重下划线
21         if (camel.isEmpty()) {
22             continue;
23         }
24         // 处理真正的驼峰片段
25         if (result.length() == 0) {
26             // 第一个驼峰片段,全部字母都小写
27             result.append(camel.toLowerCase());
28         } else {
29             // 其他的驼峰片段,首字母大写
30             result.append(camel.substring(0, 1).toUpperCase());
31             result.append(camel.substring(1).toLowerCase());
32         }
33     }
34     return result.toString();
35 }

 参考博客:http://jhonnnnnn.iteye.com/blog/2261298

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
相关文章
|
19天前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
115 3
|
28天前
|
缓存 Java 开发者
Java 开发者必看!ArrayList 和 LinkedList 的性能厮杀:选错一次,代码慢成蜗牛
本文深入解析了 Java 中 ArrayList 和 LinkedList 的性能差异,揭示了它们在不同操作下的表现。通过对比随机访问、插入、删除等操作的效率,指出 ArrayList 在多数场景下更高效,而 LinkedList 仅在特定情况下表现优异。文章强调选择合适容器对程序性能的重要性,并提供了实用的选择法则。
102 3
|
2月前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
|
2月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
191 46
|
2月前
|
算法 IDE Java
Java 项目实战之实际代码实现与测试调试全过程详解
本文详细讲解了Java项目的实战开发流程,涵盖项目创建、代码实现(如计算器与汉诺塔问题)、单元测试(使用JUnit)及调试技巧(如断点调试与异常排查),帮助开发者掌握从编码到测试调试的完整技能,提升Java开发实战能力。
261 0
|
3月前
|
安全 Java 测试技术
Java 项目实战中现代技术栈下代码实现与测试调试的完整流程
本文介绍基于Java 17和Spring技术栈的现代化项目开发实践。项目采用Gradle构建工具,实现模块化DDD分层架构,结合Spring WebFlux开发响应式API,并应用Record、Sealed Class等新特性。测试策略涵盖JUnit单元测试和Testcontainers集成测试,通过JFR和OpenTelemetry实现性能监控。部署阶段采用Docker容器化和Kubernetes编排,同时展示异步处理和反应式编程的性能优化。整套方案体现了现代Java开发的最佳实践,包括代码实现、测试调试
133 0
|
3月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
203 0
|
3月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
120 0
|
3月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
130 0