使用jparsec,我试图解析可能为负的数字:
@Test
public void canParseIntegerValues() {
assertEquals(0, ValueParser.PARSER.parse("0"));
assertEquals(276, ValueParser.PARSER.parse("276"));
assertEquals(-3874, ValueParser.PARSER.parse("-3874"));
}
我无法弄清楚如何声明
PARSER
。我试过了:private static final Parser<Integer> INTEGER_VALUE_PARSER = Terminals.IntegerLiteral.TOKENIZER
.map(new Map<Fragment, Integer>() {
@Override
public Integer map(Fragment from) {
return Integer.valueOf(from.text());
}
});
这不起作用,因为
Terminals.IntegerLiteral.TOKENIZER
不包含减号。接下来,我尝试了:private static final Parser<Integer> INTEGER_VALUE_PARSER = Parsers.sequence(
Scanners.string("-").optional().token(),
Terminals.IntegerLiteral.TOKENIZER
.map(new Map<Fragment, Integer>() {
@Override
public Integer map(Fragment from) {
return Integer.valueOf(from.text());
}
}));
这也行不通,因为负号被舍弃了,而我的地图函数再也看不到它了。
谁能告诉我如何使用jparsec正确解析可能为正数或不为正的整数?
编辑:我找到了一种方法,但是我很难相信这是最好的方法:
private static final Parser<Integer> INTEGER_VALUE_PARSER = Parsers.sequence(
Scanners.string("-").many(),
Terminals.IntegerLiteral.TOKENIZER,
new Map2<List<Void>, Fragment, Integer>() {
@Override
public Integer map(List<Void> from1, Fragment from2) {
boolean isNegative = (from1.size() % 2) == 1;
if (isNegative) {
return -1 * Integer.valueOf(from2.text());
} else {
return Integer.valueOf(from2.text());
}
}
});
最佳答案
您可以在jparsec的示例中查看Calculator
类:https://github.com/abailly/jparsec/blob/master/jparsec-examples/src/main/java/org/codehaus/jparsec/examples/calculator/Calculator.java在这里,负整数被视为已应用前缀-
运算符的整数。
另外,您可以简单地声明一个包含减号的模式:
public void test() {
Pattern regex = Patterns.regex("-?\\d+");
Parser<Integer> integer = Scanners.pattern(regex, "Integer").source().map(new Map<String, Integer>() {
@Override
public Integer map(String s) {
return Integer.parseInt(s);
}
});
assertEquals(-42, (int) integer.parse("-42"));
}
高温超导
阿诺