带有空标记的Java StringTokenizer

带有空标记的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

我有一个字符串,看起来像-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";
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]