我正在尝试将输入程序中的某些标记文本替换为特定格式的文本。我使用 C# 作为输出语言。
输入示例:
time#1m2s
该输入的 lex 语法:
fragment
DIGIT : '0'..'9'
;
CTE_DURATION
: ('T'|'t'|'TIME'|'time') '#' '-'? (DIGIT ('d'|'h'|'m'|'s'|'ms') '_'?)+
;
我想从输入示例中获取的输出标记文本:
0.0:1:2.0
这意味着:0 天、0 小时、1 分钟、2 秒和 0 毫秒。
有什么建议吗?预先感谢您。
最佳答案
这里有一种方法可以做到这一点(它是用 Java 编写的,但移植到 C# 应该不难):
grammar Test;
parse
: CTE_DURATION EOF
;
CTE_DURATION
: ('T' 'IME'? | 't' 'ime'?) '#' minus='-'?
(d=DIGITS 'd')? (h=DIGITS 'h')? (m=DIGITS 'm')? (s=DIGITS 's')? (ms=DIGITS 'ms')?
{
int days = $d == null ? 0 : Integer.valueOf($d.text);
int hours = $h == null ? 0 : Integer.valueOf($h.text);
int minutes = $m == null ? 0 : Integer.valueOf($m.text);
int seconds = $s == null ? 0 : Integer.valueOf($s.text);
int mseconds = $ms == null ? 0 : Integer.valueOf($ms.text);
setText(($minus == null ? "" : "-") + days + "." + hours + ":" + minutes + ":" + seconds + "." + mseconds);
}
;
fragment DIGITS : '0'..'9'+;
解析输入 time#1m2s
会产生以下解析树:
请注意,语法现在也接受 time#
(导致它生成 0.0:0:0.0
),但您可以轻松地从词法分析器规则中生成异常如果这样的输入无效。
关于c# - 替换 ANTLR 中标记的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10314104/