C# 使用ANTLR4解析并返回一个double列表
如何使用ANTLR4将包含十进制数字的文件解析为C#中的C# 使用ANTLR4解析并返回一个double列表,c#,antlr,antlr4,C#,Antlr,Antlr4,如何使用ANTLR4将包含十进制数字的文件解析为C#中的列表?一个完整的工作示例将说明所有部分是如何组合在一起的 输入文件如下所示: 12.34 45.67 89.10 这是对另一个问题的旧答案的更新版本,显示了使用C#和ANTLR4完成此任务的一种方法 语法 听众 现在是实现侦听器模式的类,现在正在侦听编号: 使用ANTLR来完成这样的任务似乎有点过分了。是的,Bart,很明显,几乎每种语言都有更简单的方法来解析这样的文件。你出色的Mu项目对于一个计算器来说太过分了,但当我努力学习表达式求值
列表
?一个完整的工作示例将说明所有部分是如何组合在一起的
输入文件如下所示:
12.34
45.67
89.10
这是对另一个问题的旧答案的更新版本,显示了使用C#和ANTLR4完成此任务的一种方法 语法 听众 现在是实现侦听器模式的类,现在正在侦听编号:
使用ANTLR来完成这样的任务似乎有点过分了。是的,Bart,很明显,几乎每种语言都有更简单的方法来解析这样的文件。你出色的Mu项目对于一个计算器来说太过分了,但当我努力学习表达式求值时,它给了我那个“啊哈!”的时刻。我只想给那些仍然在寻找C#、ANTLR4和Listener模式的“啊哈!”时刻的人一个简单的例子。这是一个很小但很完整的例子,希望能激发一些理解。谢谢你帮助我理解。
grammar Values;
parse : (number ( LINEBREAK | EOF ) )* ;
number : NUMBER ;
NUMBER : DIGIT '.' DIGIT ;
DIGIT : [0-9]+ ;
WS : [ \t] -> channel(HIDDEN) ;
LINEBREAK : '\r'? '\n' | '\r' ;
using System;
using System.Collections.Generic;
namespace ANTLR_File_To_Arrray
{
public class ValuesListener : ValuesBaseListener
{
public List<double> doubles = new List<double>();
public override void ExitNumber(ValuesParser.NumberContext context)
{
doubles.Add(Convert.ToDouble(context.GetChild(0).GetText()));
}
}
}
using System;
using System.IO;
using Antlr4.Runtime;
using Antlr4;
using Antlr4.Runtime.Tree;
namespace ANTLR_File_To_Arrray
{
class Program
{
static void Main(string[] args)
{
const string SOURCEFILE = @"D:\prj\ANTLR_File_To_Arrray\ANTLR_File_To_Arrray\source1.txt";
using (StreamReader fileStream = new StreamReader(SOURCEFILE))
{
AntlrInputStream inputStream = new AntlrInputStream(fileStream);
ValuesLexer lexer = new ValuesLexer(inputStream);
CommonTokenStream tokenStream = new CommonTokenStream(lexer);
ValuesParser parser = new ValuesParser(tokenStream);
ValuesParser.ParseContext context = parser.parse();
ValuesListener listener = new ValuesListener();
ParseTreeWalker walker = new ParseTreeWalker();
bool built = parser.BuildParseTree;
walker.Walk(listener, context);
foreach (double d in listener.doubles)
Console.WriteLine(d);
Console.ReadKey();
}
}
}
}