基本每个项目都会使用到驼峰格式和下划线格式之间的转换,这里提供一个使用正则进行转换的例子
- 代码如下:
public class Test {
public static void main(String[] args) {
String str = "helloWordTestHe";
System.out.println(xX2x_x(str));
String str1 = "hello_Word_tESt_he";
System.out.println(x_x2xX(str1));
}
/**
* @author Howe
* @Description 将驼峰转为下划线
* @param str
* @return java.lang.String
* @Date 2022/4/22 13:11
* @since 1.0.0
*/
public static String xX2x_x(String str) {
Pattern compile = Pattern.compile("[A-Z]");
Matcher matcher = compile.matcher(str);
StringBuffer sb = new StringBuffer();
while(matcher.find()) {
matcher.appendReplacement(sb, "_" + matcher.group(0).toLowerCase());
}
matcher.appendTail(sb);
return sb.toString();
}
/**
* @author Howe
* @Description 将下划线转为驼峰
* @param str
* @return java.lang.String
* @Date 2022/4/22 13:12
* @since 1.0.0
*/
public static String x_x2xX(String str) {
str = str.toLowerCase();
Pattern compile = Pattern.compile("_[a-z]");
Matcher matcher = compile.matcher(str);
StringBuffer sb = new StringBuffer();
while(matcher.find()) {
matcher.appendReplacement(sb, matcher.group(0).toUpperCase().replace("_",""));
}
matcher.appendTail(sb);
return sb.toString();
}
}
- 运行结果如下:
hello_word_test_he
helloWordTestHe - api解读
matcher.appendReplacement(StringBuffer sb, String replacement) :将当前匹配的子串替换为指定字符串,并且将替换后的子串与上次操作后的字符串拼接到一起后添加到一个 StringBuffer 对象里,例如上面的xX2x_x方法中操作helloWordTestHe这个字符串。每次的操作结果是:
hello_w
hello_word_t
hello_word_test_h
hello_word_test_he
appendTail(StringBuffer sb):将最后一次匹配后剩余的字符串添加到StringBuffer 对象中