基本每个项目都会使用到驼峰格式和下划线格式之间的转换,这里提供一个使用正则进行转换的例子

  1. 代码如下:
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();
    }
}
  1. 运行结果如下:
    hello_word_test_he
    helloWordTestHe
  2. 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 对象中