相信大家都自己封装过或者用过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,反向截取。
具体代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
/** * 从头开始截取 * * @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方法来测试一下吧:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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 )); } |
结果如下:
再附赠一个小功能吧:字符串数组用指定字符串链接。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/** * 用指定字符串数组相连接,并返回 * * @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 ; } |
效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/xiaoxian8023/article/details/49834643