带有空标记的Java StringTokenizer
我有一个字符串,看起来像-56,0,76,0,93,,,,,,1230。 我使用StringTokenizer将其拆分为“,”。然而,这似乎是从93直接跳到1230。有没有办法让它在移动到1230之前返回六个空字符串?与带有空标记的Java StringTokenizer,java,stringtokenizer,Java,Stringtokenizer,我有一个字符串,看起来像-56,0,76,0,93,,,,,,1230。 我使用StringTokenizer将其拆分为“,”。然而,这似乎是从93直接跳到1230。有没有办法让它在移动到1230之前返回六个空字符串?与returnDelims一起使用,设置为true 如果returnDelims标志为true,则分隔符字符也将作为标记返回。每个分隔符作为长度为1的字符串返回 改用String.split()方法 String str = "56,0,76,0,93,,,,,,,1230"; S
returnDelims
一起使用,设置为true
如果returnDelims标志为true,则分隔符字符也将作为标记返回。每个分隔符作为长度为1的字符串返回
改用String.split()
方法
String str = "56,0,76,0,93,,,,,,,1230";
String[] stringArr = str.split(",");
这将返回一个字符串数组。String.split(“,”,-1);
如果没有-1,它将忽略尾随分隔符与限制一起使用作为-1
示例代码:
System.out.println(Arrays.toString(",,-56,0,76,0,93,,,,,,,1230,".split(",",-1)));
输出:
[, , -56, 0, 76, 0, 93, , , , , , , 1230, ]
StringTokenizer有一个构造函数,它接受3个参数,第三个参数是一个布尔值,用于控制分隔符是否作为标记返回。你应该把它设为真
new StringTokenizer(yourString, yourDelimiters, true);
现在也返回了分隔符,通过检查两个连续标记是否为分隔符,很容易判断是否存在空字符串
您可以扩展标记器或编写自己的包装器类以供重用。使用Google的Guava lib拆分器
String str = "56,0,76,0,93,,,,,,,1230";
Iterable<String> splitResult = Splitter.on(",").split(str);
请查找工作副本以克服空令牌
public class TestStringTokenStrict {
/**
* Strict implementation of StringTokenizer
*
* @param str
* @param delim
* @param strict
* true = include NULL Token
* @return
*/
static StringTokenizer getStringTokenizerStrict(String str, String delim, boolean strict) {
StringTokenizer st = new StringTokenizer(str, delim, strict);
StringBuffer sb = new StringBuffer();
while (st.hasMoreTokens()) {
String s = st.nextToken();
if (s.equals(delim)) {
sb.append(" ").append(delim);
} else {
sb.append(s).append(delim);
if (st.hasMoreTokens())
st.nextToken();
}
}
return (new StringTokenizer(sb.toString(), delim));
}
static void altStringTokenizer(StringTokenizer st) {
while (st.hasMoreTokens()) {
String type = st.nextToken();
String one = st.nextToken();
String two = st.nextToken();
String three = st.nextToken();
String four = st.nextToken();
String five = st.nextToken();
System.out.println(
"[" + type + "] [" + one + "] [" + two + "] [" + three + "] [" + four + "] [" + five + "]");
}
}
public static void main(String[] args) {
String input = "Record|One||Three||Five";
altStringTokenizer(getStringTokenizerStrict(input, "|", true));
}}
输出将是
[Record] [One] [ ] [Three] [ ] [Five]
是否已选中java.util.Scanner?如果字符串的结尾或开头有逗号,则此选项无效。看我的answer@user3218114,事实上,是的。我刚刚试过运行它。试一下,-56,0,76,0,93,,,,,,,,1230,
即使你不输入-1,它也不会忽略尾随的分隔符。我同意你的答案应该是正确的。
[Record] [One] [ ] [Three] [ ] [Five]