如何忽略ANTLR4中的某些文本?

问题描述 投票:0回答:1

首先,提前感谢您的回答,这个问题正在扼杀我

  1. 我的第一个问题是如何忽略某些文字?我想忽略我的文档中的某些文本,我有下一个文本:

Text

我想忽略矩形所包含的文本......当词法分析器找到“demandante”字时,它将停止忽略...

我用过这个语法

grammar A;

documento:((acciondemandante acciondemandado) | (acciondemandado acciondemandante));
acciondemandante: PALABRASDEMANDA informacionentidad+;
acciondemandado: PALABRASDEMANDADO informacionentidad+;
informacionentidad: nombres distancia? identificacion;
nombres: nombrenormal|nombremayuscula; 
nombrenormal: WORDCAPITALIZE WORDCAPITALIZE+;
nombremayuscula: WORDUPPER WORDUPPER+;
distancia: WORDLOWER;
identificacion: tipo indicador? INT+;
tipo: cedula | NIT;
cedula: CEDULA | LCASE_LETTER LCASE_LETTER | UCASE_LETTER UCASE_LETTER;
indicador: WORDCAPITALIZE | WORDLOWER;

CEDULA: 'cedula' | 'cc' | 'CC';
NIT: 'NIT' | 'nit';
PALABRASDEMANDADO: 'demandados' | 'demandado';
PALABRASDEMANDA: 'demandante' | 'demandantes';
WORDUPPER: UCASE_LETTER UCASE_LETTER+;
WORDLOWER: LCASE_LETTER LCASE_LETTER+;
WORDCAPITALIZE: UCASE_LETTER LCASE_LETTER+;
LCASE_LETTER: 'a'..'z' | 'ñ' | 'á' | 'é' | 'í' | 'ó' | 'ú';
UCASE_LETTER: 'A'..'Z' | 'Ñ' | 'Á' | 'É' | 'Í' | 'Ó' | 'Ú';
INT: DIGIT+;
DIGIT: '0'..'9';  
SPECIAL_CHAR: '.'  -> skip;
WS : [ \t\r\n]+ -> skip;
//ANY: ~[ ]+;

我试过跳过空格WS的技巧:[\ t \ r \ n] + - >跳过;然后忽略什么不是空白任何:〜[] +;但它不起作用,因为词法分析器永远不会识别任何令牌......

我希望我的语法阅读

废话废话请求Julian Solarte c.c 120109321废话废话

  1. 我的第二个问题是我遇到了“不匹配的输入”问题,为了解决这个问题,我添加了这个规则“SKIPEND:EOF - > skip;”但它不起作用......

谢谢,非常感谢你。

java antlr antlr4
1个回答
1
投票

我解决这个问题的方法是两个步骤:

  1. 在输入流中找到关键字(此处为demandado)。
  2. 让解析器从该位置解析而不强制语法输入的EOF。在理解之后,它将尽可能地忽略它所不理解的一切。

这将使您的语法更简单,您将只获得相关输入的解析树。

© www.soinside.com 2019 - 2024. All rights reserved.