相信大家都自己封装过或者用过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