字符串split问题求解(50分,解决立即结贴)
String line = "aa|bb|cc|| ";
String[] array = line.split( "\\| ");
System.out.println( "length = " + array.length);
如何才能是输出 length = 4
即如何能使array内容为 { "aa ", "bb ", "cc ", " "}
先在此谢过。
[解决办法]
line.split( "\\| ",-1);
[解决办法]
split方法在处理字符串时,当发现最后一个分隔符后面没有值后,是不算最后一个值的,而中间发现其中两个分隔符之间没有值时,也不计算,因此你需要用楼上的方法,也就是line.split( "\\| ",-1);然后判断line是不是以分隔符结尾的,line.endsWith( "\\| "),如果是的,就将得到的值减一,否则保持不变。
[解决办法]
line.split( "[\\|]+ ",-1);
line.split( "[\\|]+ ",5);
line.split( "[\\|]+ ",4);
[解决办法]
split方法在处理字符串时,当发现最后一个分隔符后面没有值后,是不算最后一个值的,而中间发现其中两个分隔符之间没有值时,也不计算,因此你需要用楼上的方法,也就是line.split( "\\| ",-1);然后判断line是不是以分隔符结尾的,line.endsWith( "\\| "),如果是的,就将得到的值减一,否则保持不变。
==================
实在不行,可能采纳。
[解决办法]
split
public String[] split(String regex,
int limit)根据匹配给定的正则表达式来拆分此字符串。
此方法返回的数组包含此字符串的每个子字符串,这些子字符串由另一个匹配给定的表达式的子字符串终止或由字符串结束来终止。数组中的子字符串按它们在此字符串中的顺序排列。如果表达式不匹配输入的任何部分,则结果数组只具有一个元素,即此字符串。
limit 参数控制模式应用的次数,因此影响结果数组的长度。如果该限制 n 大于 0,则模式将被最多应用 n - 1 次,数组的长度将不会大于 n,而且数组的最后项将包含超出最后匹配的定界符的所有输入。如果 n 为非正,则模式将被应用尽可能多的次数,而且数组可以是任意长度。如果 n 为零,则模式将被应用尽可能多的次数,数组可有任何长度,并且结尾空字符串将被丢弃。
例如,字符串 "boo:and:foo " 使用这些参数可生成下列结果:
Regex Limit 结果
: 2 { "boo ", "and:foo " }
: 5 { "boo ", "and ", "foo " }
: -2 { "boo ", "and ", "foo " }
o 5 { "b ", " ", ":and:f ", " ", " " }
o -2 { "b ", " ", ":and:f ", " ", " " }
o 0 { "b ", " ", ":and:f " }
这种形式的方法调用 str.split(regex, n) 产生与以下表达式完全相同的结果:
Pattern.compile(regex).split(str, n)
参数:
regex - 定界正则表达式
limit - 结果阈值,如上所述
返回:
字符串数组,根据给定正则表达式的匹配来拆分此字符串,从而生成此数组
抛出:
PatternSyntaxException - 如果正则表达式的语法无效
从以下版本开始:
1.4
另请参见:
Pattern
[解决办法]
楼主尝试一下:)
返回的是个集合,处理一下就可以得到数组了。
----------------------------------------
public List toArray(String sourceString, char split) {
List result = new ArrayList();
if (sourceString == null || sourceString.equals( " ")) {
return result;
}
StringBuffer str = new StringBuffer(sourceString);
int size = str.length();
int oldIndexOfSplit = 0;
for (int i = 0; i < size; i++) {
if (str.charAt(i) == split) {
if (i != 0) {
result.add(str.substring(oldIndexOfSplit, i));
}
oldIndexOfSplit = i + 1;
}
}
if (oldIndexOfSplit != size) {
result.add(str.substring(oldIndexOfSplit));
}
return result;
}
------解决方案--------------------
我觉得在可不必研究这个,如果非要处理这个字符串的我们可以自己写一个split方法,比如emin_lee() 的方法;要不我想应该不会遇到要算是这个串的情况吧,因为这个串实在有些特殊,不知说得对不对,不过还是请楼主换个角度考虑一下,我想可以避开这个问题。