Java常用字符串工具类 字符串智能截取(3)

 更新时间:2017年05月09日 17:18:09   作者:龙轩  
这篇文章主要为大家详细介绍了Java常用字符串工具类,字符串的智能截取,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

前两篇博文简单分享了一下数字工具类,现在说说字符串工具类。

相信大家都自己封装过或者用过guava封装的Strings,但是有没有可以智能截取,比如说“截取整数第二个到倒数第二个”的字符串。你是否还需要自己写str.substring(1,str.length()-2)。如果是的话,请继续往下看吧。暂时还未见过可以反向截取字符串的。一般都是substring(str, start, end)或者substring(str, len);而这里的参数都必须是正数,否则就会报错。所以为了改善这些方法,我简单封装了一下substring这个方法,提供了4种最常用的方法:

  • subStrStart(String str, int end),正向截取
  • subStrEnd(String str, int start),反向截取
  • subStr(String str, int length),支持双向截取,length>0正向截取,<0,反向截取
  • subStr(String str, int start, int end),支持双向截取,start、length>0正向截取,<0,反向截取。

具体代码如下:

/** 
 * 从头开始截取 
 * 
 * @param str 字符串 
 * @param end 结束位置 
 * @return 
 */ 
public static String subStrStart(String str, int end){ 
  return subStr(str, 0, end); 
} 
 
/** 
 * 从尾开始截取 
 * 
 * @param str 字符串 
 * @param start 开始位置 
 * @return 
 */ 
public static String subStrEnd(String str, int start){ 
  return subStr(str, str.length()-start, str.length()); 
} 
 
/** 
 * 截取字符串 (支持正向、反向截取)<br/> 
 * 
 * @param str 待截取的字符串 
 * @param length 长度 ,>=0时,从头开始向后截取length长度的字符串;<0时,从尾开始向前截取length长度的字符串 
 * @return 返回截取的字符串 
 * @throws RuntimeException 
 */ 
public static String subStr(String str, int length) throws RuntimeException{ 
  if(str==null){ 
    throw new NullPointerException("字符串为null"); 
  } 
  int len = str.length(); 
  if(len<Math.abs(length)){ 
    throw new StringIndexOutOfBoundsException("最大长度为"+len+",索引超出范围为:"+(len-Math.abs(length))); 
  } 
  if(length>=0){ 
    return subStr(str, 0,length); 
  }else{ 
    return subStr(str, len-Math.abs(length), len); 
  } 
} 
 
 
/** 
 * 截取字符串 (支持正向、反向选择)<br/> 
 * 
 * @param str 待截取的字符串 
 * @param start 起始索引 ,>=0时,从start开始截取;<0时,从length-|start|开始截取 
 * @param end 结束索引 ,>=0时,从end结束截取;<0时,从length-|end|结束截取 
 * @return 返回截取的字符串 
 * @throws RuntimeException 
 */ 
public static String subStr(String str, int start, int end) throws RuntimeException{ 
  if(str==null){ 
    throw new NullPointerException(""); 
  } 
  int len = str.length(); 
  int s = 0;//记录起始索引 
  int e = 0;//记录结尾索引 
  if(len<Math.abs(start)){ 
    throw new StringIndexOutOfBoundsException("最大长度为"+len+",索引超出范围为:"+(len-Math.abs(start))); 
  }else if(start<0){ 
    s = len - Math.abs(start); 
  }else if(start<0){ 
    s=0; 
  }else{//>=0 
    s = start; 
  } 
  if(len<Math.abs(end)){ 
    throw new StringIndexOutOfBoundsException("最大长度为"+len+",索引超出范围为:"+(len-Math.abs(end))); 
  }else if (end <0){ 
    e = len - Math.abs(end); 
  }else if (end==0){ 
    e = len; 
  }else{//>=0 
    e = end; 
  } 
  if(e<s){ 
    throw new StringIndexOutOfBoundsException("截至索引小于起始索引:"+(e-s)); 
  } 
 
  return str.substring(s, e); 
} 

写一个main方法来测试一下吧:

public static void main(String[] args) { 
  String str = "12345abcde"; 
  System.out.println("--------------------------------"); 
  System.out.println("正向截取长度为4,结果:\n" + StringsUtil.subStr(str, 4)); 
  System.out.println("反向截取长度为4,结果:\n" + StringsUtil.subStr(str, -4)); 
  System.out.println("--------------------------------"); 
  System.out.println("正向截取到第4个字符的位置,结果:\n" + StringsUtil.subStrStart(str, 4)); 
  System.out.println("反向截取到第4个字符的位置,结果:\n" + StringsUtil.subStrEnd(str, 4)); 
  System.out.println("--------------------------------"); 
  System.out.println("从第2个截取到第9个,结果:\n" + StringsUtil.subStr(str, 1, 9)); 
  System.out.println("从第2个截取到倒数第1个,结果:\n" + StringsUtil.subStr(str, 1, -1)); 
  System.out.println("从倒数第4个开始截取,结果:\n" + StringsUtil.subStr(str, -4, 0)); 
  System.out.println("从倒数第4个开始截取,结果:\n" + StringsUtil.subStr(str, -4, 10)); 
} 

结果如下:


再附赠一个小功能吧:字符串数组用指定字符串链接。

/** 
 * 用指定字符串数组相连接,并返回 
 * 
 * @param strs 字符串数组 
 * @param splitStr 连接数组的字符串 
 * @return 
 */ 
public static String join(String[] strs, String splitStr){ 
  if(strs!=null){ 
    if(strs.length==1){ 
      return strs[0]; 
    } 
    StringBuffer sb = new StringBuffer(); 
    for (String str : strs) { 
      sb.append(str).append(splitStr); 
    } 
    if(sb.length()>0){ 
      sb.delete(sb.length()-splitStr.length(), sb.length()); 
    } 
    return sb.toString(); 
  } 
  return null; 
} 

效果如下:


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 使用SpringBoot中整合Redis

    使用SpringBoot中整合Redis

    这篇文章主要介绍了使用SpringBoot中整合Redis,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Java Predicate接口定义详解

    Java Predicate接口定义详解

    Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,这篇文章主要介绍了Java Predicate接口的定义及示例代码,需要的朋友可以参考下
    2025-04-04
  • idea如何解决commit代码时一直code Analyze加载的问题

    idea如何解决commit代码时一直code Analyze加载的问题

    文章介绍了解决Git提交代码时出现codeAnalyze加载卡顿问题的方法,即关闭IDEA中的相关设置选项,作者分享个人经验,希望对大家有所帮助,并鼓励支持脚本之家
    2025-01-01
  • Java中的原生post请求方式

    Java中的原生post请求方式

    这篇文章主要介绍了Java中的原生post请求方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Java Web项目创建并实现前后端交互

    Java Web项目创建并实现前后端交互

    本文主要介绍了Java Web项目创建并实现前后端交互,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • PowerJob的QueryConvertUtils工作流程源码解读

    PowerJob的QueryConvertUtils工作流程源码解读

    这篇文章主要为大家介绍了PowerJob的QueryConvertUtils工作流程源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • jsch中ChannelShell与ChannelExec的区别及说明

    jsch中ChannelShell与ChannelExec的区别及说明

    这篇文章主要介绍了jsch中ChannelShell与ChannelExec的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 解决nacos修改配置信息后需要重启服务才能生效的问题

    解决nacos修改配置信息后需要重启服务才能生效的问题

    当配置信息发生变动时,传统修改配置信息后,需要重新重启服务器才可以生效,大量应用配置修改时,需要一个个修改配置,无法统一修改,且没有办法回溯配置版本,所以本文给大家介绍了如何解决这些问题的方法,需要的朋友可以参考下
    2023-10-10
  • SpringBoot整合WebSocket实现实时通信功能

    SpringBoot整合WebSocket实现实时通信功能

    在当今互联网时代,实时通信已经成为了许多应用程序的基本需求,而WebSocket作为一种全双工通信协议,为开发者提供了一种简单、高效的实时通信解决方案,本文将介绍如何使用SpringBoot框架来实现WebSocket的集成,快速搭建实时通信功能,感兴趣的朋友可以参考下
    2023-11-11
  • JAVA编程实现TCP网络通讯的方法示例

    JAVA编程实现TCP网络通讯的方法示例

    这篇文章主要介绍了JAVA编程实现TCP网络通讯的方法,简单说明了TCP通讯的原理并结合具体实例形式分析了java实现TCP通讯的步骤与相关操作技巧,需要的朋友可以参考下
    2017-08-08

最新评论