mirror of
https://gitee.com/chinabugotech/hutool.git
synced 2025-05-09 23:51:34 +08:00
add NammingCase
This commit is contained in:
parent
0060d5ebbb
commit
d29cd5c9ea
@ -6,6 +6,7 @@
|
||||
# 5.7.10 (2021-08-17)
|
||||
|
||||
### 🐣新特性
|
||||
* 【core 】 增加NamingCase类
|
||||
### 🐞Bug修复
|
||||
|
||||
-------------------------------------------------------------------------------------------------------------
|
||||
|
@ -4016,9 +4016,10 @@ public class CharSequenceUtil {
|
||||
*
|
||||
* @param str 转换前的驼峰式命名的字符串,也可以为下划线形式
|
||||
* @return 转换后下划线方式命名的字符串
|
||||
* @see NamingCase#toUnderlineCase(CharSequence)
|
||||
*/
|
||||
public static String toUnderlineCase(CharSequence str) {
|
||||
return toSymbolCase(str, CharUtil.UNDERLINE);
|
||||
return NamingCase.toUnderlineCase(str);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -4028,58 +4029,10 @@ public class CharSequenceUtil {
|
||||
* @param symbol 连接符
|
||||
* @return 转换后符号连接方式命名的字符串
|
||||
* @since 4.0.10
|
||||
* @see NamingCase#toSymbolCase(CharSequence, char)
|
||||
*/
|
||||
public static String toSymbolCase(CharSequence str, char symbol) {
|
||||
if (str == null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
final int length = str.length();
|
||||
final StrBuilder sb = new StrBuilder();
|
||||
char c;
|
||||
for (int i = 0; i < length; i++) {
|
||||
c = str.charAt(i);
|
||||
if (Character.isUpperCase(c)) {
|
||||
final Character preChar = (i > 0) ? str.charAt(i - 1) : null;
|
||||
final Character nextChar = (i < str.length() - 1) ? str.charAt(i + 1) : null;
|
||||
|
||||
if (null != preChar) {
|
||||
if (symbol == preChar) {
|
||||
// 前一个为分隔符
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
//普通首字母大写,如_Abb -> _abb
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
//后一个为大写,按照专有名词对待,如_AB -> _AB
|
||||
} else if (Character.isLowerCase(preChar)) {
|
||||
// 前一个为小写
|
||||
sb.append(symbol);
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
//普通首字母大写,如aBcc -> a_bcc
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如aBC -> a_BC
|
||||
} else {
|
||||
//前一个为大写
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
// 普通首字母大写,如ABcc -> A_bcc
|
||||
sb.append(symbol);
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如ABC -> ABC
|
||||
}
|
||||
} else {
|
||||
// 首字母,需要根据后一个判断是否转为小写
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
// 普通首字母大写,如Abc -> abc
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如ABC -> ABC
|
||||
}
|
||||
}
|
||||
sb.append(c);
|
||||
}
|
||||
return sb.toString();
|
||||
return NamingCase.toSymbolCase(str, symbol);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -4088,33 +4041,10 @@ public class CharSequenceUtil {
|
||||
*
|
||||
* @param name 转换前的下划线大写方式命名的字符串
|
||||
* @return 转换后的驼峰式命名的字符串
|
||||
* @see NamingCase#toCamelCase(CharSequence)
|
||||
*/
|
||||
public static String toCamelCase(CharSequence name) {
|
||||
if (null == name) {
|
||||
return null;
|
||||
}
|
||||
|
||||
final String name2 = name.toString();
|
||||
if (contains(name2, CharUtil.UNDERLINE)) {
|
||||
final int length = name2.length();
|
||||
final StringBuilder sb = new StringBuilder(length);
|
||||
boolean upperCase = false;
|
||||
for (int i = 0; i < length; i++) {
|
||||
char c = name2.charAt(i);
|
||||
|
||||
if (c == CharUtil.UNDERLINE) {
|
||||
upperCase = true;
|
||||
} else if (upperCase) {
|
||||
sb.append(Character.toUpperCase(c));
|
||||
upperCase = false;
|
||||
} else {
|
||||
sb.append(Character.toLowerCase(c));
|
||||
}
|
||||
}
|
||||
return sb.toString();
|
||||
} else {
|
||||
return name2;
|
||||
}
|
||||
return NamingCase.toCamelCase(name);
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------------ isSurround
|
||||
|
179
hutool-core/src/main/java/cn/hutool/core/text/NamingCase.java
Normal file
179
hutool-core/src/main/java/cn/hutool/core/text/NamingCase.java
Normal file
@ -0,0 +1,179 @@
|
||||
package cn.hutool.core.text;
|
||||
|
||||
import cn.hutool.core.util.CharUtil;
|
||||
import cn.hutool.core.util.StrUtil;
|
||||
|
||||
/**
|
||||
* 命名规则封装,主要是针对驼峰风格命名、连接符命名等的封装
|
||||
*
|
||||
* @author looly
|
||||
* @since 5.7.10
|
||||
*/
|
||||
public class NamingCase {
|
||||
|
||||
/**
|
||||
* 将驼峰式命名的字符串转换为下划线方式,又称SnakeCase、underScoreCase。<br>
|
||||
* 如果转换前的驼峰式命名的字符串为空,则返回空字符串。<br>
|
||||
* 规则为:
|
||||
* <ul>
|
||||
* <li>单字之间以下划线隔开</li>
|
||||
* <li>每个单字的首字母亦用小写字母</li>
|
||||
* </ul>
|
||||
* 例如:
|
||||
*
|
||||
* <pre>
|
||||
* HelloWorld=》hello_world
|
||||
* Hello_World=》hello_world
|
||||
* HelloWorld_test=》hello_world_test
|
||||
* </pre>
|
||||
*
|
||||
* @param str 转换前的驼峰式命名的字符串,也可以为下划线形式
|
||||
* @return 转换后下划线方式命名的字符串
|
||||
*/
|
||||
public static String toUnderlineCase(CharSequence str) {
|
||||
return toSymbolCase(str, CharUtil.UNDERLINE);
|
||||
}
|
||||
|
||||
/**
|
||||
* 将驼峰式命名的字符串转换为短横连接方式。<br>
|
||||
* 如果转换前的驼峰式命名的字符串为空,则返回空字符串。<br>
|
||||
* 规则为:
|
||||
* <ul>
|
||||
* <li>单字之间横线线隔开</li>
|
||||
* <li>每个单字的首字母亦用小写字母</li>
|
||||
* </ul>
|
||||
* 例如:
|
||||
*
|
||||
* <pre>
|
||||
* HelloWorld=》hello-world
|
||||
* Hello_World=》hello-world
|
||||
* HelloWorld_test=》hello-world-test
|
||||
* </pre>
|
||||
*
|
||||
* @param str 转换前的驼峰式命名的字符串,也可以为下划线形式
|
||||
* @return 转换后下划线方式命名的字符串
|
||||
*/
|
||||
public static String toKebabCase(CharSequence str) {
|
||||
return toSymbolCase(str, CharUtil.DASHED);
|
||||
}
|
||||
|
||||
/**
|
||||
* 将驼峰式命名的字符串转换为使用符号连接方式。如果转换前的驼峰式命名的字符串为空,则返回空字符串。<br>
|
||||
*
|
||||
* @param str 转换前的驼峰式命名的字符串,也可以为符号连接形式
|
||||
* @param symbol 连接符
|
||||
* @return 转换后符号连接方式命名的字符串
|
||||
* @since 4.0.10
|
||||
*/
|
||||
public static String toSymbolCase(CharSequence str, char symbol) {
|
||||
if (str == null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
final int length = str.length();
|
||||
final StrBuilder sb = new StrBuilder();
|
||||
char c;
|
||||
for (int i = 0; i < length; i++) {
|
||||
c = str.charAt(i);
|
||||
if (Character.isUpperCase(c)) {
|
||||
final Character preChar = (i > 0) ? str.charAt(i - 1) : null;
|
||||
final Character nextChar = (i < str.length() - 1) ? str.charAt(i + 1) : null;
|
||||
|
||||
if (null != preChar) {
|
||||
if (symbol == preChar) {
|
||||
// 前一个为分隔符
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
//普通首字母大写,如_Abb -> _abb
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
//后一个为大写,按照专有名词对待,如_AB -> _AB
|
||||
} else if (Character.isLowerCase(preChar)) {
|
||||
// 前一个为小写
|
||||
sb.append(symbol);
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
//普通首字母大写,如aBcc -> a_bcc
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如aBC -> a_BC
|
||||
} else {
|
||||
//前一个为大写
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
// 普通首字母大写,如ABcc -> A_bcc
|
||||
sb.append(symbol);
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如ABC -> ABC
|
||||
}
|
||||
} else {
|
||||
// 首字母,需要根据后一个判断是否转为小写
|
||||
if (null == nextChar || Character.isLowerCase(nextChar)) {
|
||||
// 普通首字母大写,如Abc -> abc
|
||||
c = Character.toLowerCase(c);
|
||||
}
|
||||
// 后一个为大写,按照专有名词对待,如ABC -> ABC
|
||||
}
|
||||
}
|
||||
sb.append(c);
|
||||
}
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
/**
|
||||
* 将下划线方式命名的字符串转换为帕斯卡式。<br>
|
||||
* 规则为:
|
||||
* <ul>
|
||||
* <li>单字之间不以空格或任何连接符断开</li>
|
||||
* <li>第一个单字首字母采用大写字母</li>
|
||||
* <li>后续单字的首字母亦用大写字母</li>
|
||||
* </ul>
|
||||
* 如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。<br>
|
||||
* 例如:hello_world=》HelloWorld
|
||||
*
|
||||
* @param name 转换前的下划线大写方式命名的字符串
|
||||
* @return 转换后的驼峰式命名的字符串
|
||||
*/
|
||||
public static String toPascalCase(CharSequence name) {
|
||||
return StrUtil.upperFirst(toCamelCase(name));
|
||||
}
|
||||
|
||||
/**
|
||||
* 将下划线方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。<br>
|
||||
* 规则为:
|
||||
* <ul>
|
||||
* <li>单字之间不以空格或任何连接符断开</li>
|
||||
* <li>第一个单字首字母采用小写字母</li>
|
||||
* <li>后续单字的首字母亦用大写字母</li>
|
||||
* </ul>
|
||||
* 例如:hello_world=》helloWorld
|
||||
*
|
||||
* @param name 转换前的下划线大写方式命名的字符串
|
||||
* @return 转换后的驼峰式命名的字符串
|
||||
*/
|
||||
public static String toCamelCase(CharSequence name) {
|
||||
if (null == name) {
|
||||
return null;
|
||||
}
|
||||
|
||||
final String name2 = name.toString();
|
||||
if (StrUtil.contains(name2, CharUtil.UNDERLINE)) {
|
||||
final int length = name2.length();
|
||||
final StringBuilder sb = new StringBuilder(length);
|
||||
boolean upperCase = false;
|
||||
for (int i = 0; i < length; i++) {
|
||||
char c = name2.charAt(i);
|
||||
|
||||
if (c == CharUtil.UNDERLINE) {
|
||||
upperCase = true;
|
||||
} else if (upperCase) {
|
||||
sb.append(Character.toUpperCase(c));
|
||||
upperCase = false;
|
||||
} else {
|
||||
sb.append(Character.toLowerCase(c));
|
||||
}
|
||||
}
|
||||
return sb.toString();
|
||||
} else {
|
||||
return name2;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user