欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java字符串中${}或者{}等的占位符替換工具類

 更新時間:2018年12月11日 10:05:17   作者:lhever_  
今天小編就為大家分享一篇關于java字符串中${}或者{}等的占位符替換工具類,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

正如標題所述,這是一個替換java字符串中${}或者{}等占位符的工具類,其處理性能比較令人滿意。該類主要通過簡單的改寫myatis框架中的GenericTokenParser類得到。在日常開發(fā)過程中,可以將該類進行簡單的改進或封裝,就可以用在需要打印日志的場景中,現(xiàn)在張貼出來給有需要的人,使用方式參考main方法,不再贅述!

public class Parser {
  /**
   * 將字符串text中由openToken和closeToken組成的占位符依次替換為args數(shù)組中的值
   * @param openToken
   * @param closeToken
   * @param text
   * @param args
   * @return
   */
  public static String parse(String openToken, String closeToken, String text, Object... args) {
    if (args == null || args.length <= 0) {
      return text;
    }
    int argsIndex = 0;
    if (text == null || text.isEmpty()) {
      return "";
    }
    char[] src = text.toCharArray();
    int offset = 0;
    // search open token
    int start = text.indexOf(openToken, offset);
    if (start == -1) {
      return text;
    }
    final StringBuilder builder = new StringBuilder();
    StringBuilder expression = null;
    while (start > -1) {
      if (start > 0 && src[start - 1] == '\\') {
        // this open token is escaped. remove the backslash and continue.
        builder.append(src, offset, start - offset - 1).append(openToken);
        offset = start + openToken.length();
      } else {
        // found open token. let's search close token.
        if (expression == null) {
          expression = new StringBuilder();
        } else {
          expression.setLength(0);
        }
        builder.append(src, offset, start - offset);
        offset = start + openToken.length();
        int end = text.indexOf(closeToken, offset);
        while (end > -1) {
          if (end > offset && src[end - 1] == '\\') {
            // this close token is escaped. remove the backslash and continue.
            expression.append(src, offset, end - offset - 1).append(closeToken);
            offset = end + closeToken.length();
            end = text.indexOf(closeToken, offset);
          } else {
            expression.append(src, offset, end - offset);
            offset = end + closeToken.length();
            break;
          }
        }
        if (end == -1) {
          // close token was not found.
          builder.append(src, start, src.length - start);
          offset = src.length;
        } else {
          ///////////////////////////////////////僅僅修改了該else分支下的個別行代碼////////////////////////
          String value = (argsIndex <= args.length - 1) ?
              (args[argsIndex] == null ? "" : args[argsIndex].toString()) : expression.toString();
          builder.append(value);
          offset = end + closeToken.length();
          argsIndex++;
          ////////////////////////////////////////////////////////////////////////////////////////////////
        }
      }
      start = text.indexOf(openToken, offset);
    }
    if (offset < src.length) {
      builder.append(src, offset, src.length - offset);
    }
    return builder.toString();
  }
  public static String parse0(String text, Object... args) {
    return Parser.parse("${", "}", text, args);
  }
  public static String parse1(String text, Object... args) {
    return Parser.parse("{", "}", text, args);
  }
  /**
   * 使用示例
   * @param args
   */
  public static void main(String... args) {
    //{}被轉(zhuǎn)義,不會被替換
    System.out.println(Parser.parse("{", "}", "我的名字是\\{},結(jié)果是{},可信度是%{}", "雷鋒", true, 100));
    System.out.println(Parser.parse0("我的名字是${},結(jié)果是${},可信度是%${}", "雷鋒", true, 100));
    System.out.println(Parser.parse1("我的名字是{},結(jié)果是{},可信度是%{}", "雷鋒", true, 100));
//    輸出結(jié)果如下:
//    我的名字是{},結(jié)果是true,可信度是%100
//    我的名字是雷鋒,結(jié)果是true,可信度是%100
//    我的名字是雷鋒,結(jié)果是true,可信度是%100
  }
}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接

相關文章

最新評論