首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用antlr解析重复属性?

如何使用antlr解析重复属性?
EN

Stack Overflow用户
提问于 2016-12-11 21:46:01
回答 1查看 300关注 0票数 0

我有以下语法。

代码语言:javascript
复制
meta : '<' TAG attribute* '>';

attribute : NAME '=' VAL;

TAG : [A-Z0-9]+;

NAME : [A-Z_-]+;

VAL : '"'.*?'"';

我想要匹配下面的字符串。

代码语言:javascript
复制
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=UTF-8">

但是我得到了以下错误。

代码语言:javascript
复制
ParseError extraneous input 'CONTENT' expecting {'>', NAME}  clj-antlr.common/parse-error (common.clj:146)

我能够用一个属性进行解析。

代码语言:javascript
复制
<META HTTP-EQUIV="Content-Type">

如何解析重复属性?给attribute*不起作用。

更新:它实际上是由lexer引起的。如果我将TAGNAME结合起来,那么它就能工作。

代码语言:javascript
复制
meta : '<' NAME attribute* '>';
NAME : [A-Z0-9_-]+;

但我不想让NAME包含数字。有办法让这件事成功吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-12 10:49:16

您可以使用两个独立的lexer规则,然后使用一个解析器规则分别组合它们。

代码语言:javascript
复制
ID: [A-Za-z]+ ;
NUMBER: [0-9]+ ;

tag: ID+ tag? | NUMBER+ tag? ;
name: ID+ name?  | ('_' | '-')+ name? 

如果忽略元素之间的空格有问题,可以为其使用不同的通道--仅在上述解析器规则中启用它.它甚至可以将上述解析器规则定义为lexer规则,但我不确定.

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41091492

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档