- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想在 peg.js 中创建解析器和表达式语法,以允许我执行这些操作
基本上我想传入一个掩码并输出一个数字。
面具具有这些能力。
1) 生成一个0-9之间的随机数(字符n
for expression?)
2) 在x和y之间生成一个随机数( (x,y) for expression?)
3) 字面数字是有效的(希望不需要表达什么?)
4) 重复之前的表达式 x 次({x} for expression?)
5) 在 x 和 y 之间重复之前的表达式 ({x,y} for expression?)
所以一个示例表达式可以是
027n(5,9){4}n12{2,8}(2,4)
上面建议的表达式语法只是一个例子,它可以改变。
任何人都可以在 peg.js 中为此创建解析器提供帮助吗? ?
最佳答案
想法是让它生成一个 JavaScript 函数,该函数在执行时会根据掩码返回一个随机字符串。
文字数字是 0 到 9 之间的任何字符,所以让它生成一个返回自身的函数。
literal_number
= num:[0-9]
{ return function() {
return num;
}; }
那么n
就是一个随机数。同样,这会生成一个返回随机数的函数。我添加了 + ''
以在返回之前将其转换为字符串。
random_number
= "n"
{ return function() {
return Math.floor(Math.random() * 10) + '';
}; }
在(a,b)
语法中,a
和b
是数字,所以我们需要让它解析并返回一个数字.使用计算器示例中的声明:
number
= digits:[0-9]+ { return parseInt(digits.join(""), 10); }
然后我们可以继续为 (a,b)
语法创建规则。
random_number_between
= "(" a:number "," b:number ")"
{ return function() {
return a + Math.floor(Math.random() * (b - a + 1)) + ''
}; }
因此,这 3 个东西(literal_number、random_number、random_number_between)组合成一个生成有效函数的表达式。
single_expression
= random_number
/ random_number_between
/ literal_number
单个表达式,后跟 {n}
或 {a,b}
形成重复表达式。单个表达式也是重复表达式,重复一次。
重复表达式的思想是,给定一个函数,返回一个调用输入函数N次的函数,收集结果并返回。
repeated_expression
= ex:single_expression "{" n:number "}" {
return function() {
var result = '';
for (var i = 0; i < n; i ++) {
result += ex();
}
return result;
};
}
/ ex:single_expression "{" a:number "," b:number "}" {
return function() {
var result = '';
var n = a + Math.floor(Math.random() * (b - a + 1))
for (var i = 0; i < n; i ++) {
result += ex();
}
return result;
};
}
/ ex:single_expression
最后,重复的表达式可以并排放置。
expression
= list:repeated_expression* {
return function() {
var result = '';
for (var i = 0; i < list.length; i ++) {
result += list[i]();
}
return result;
};
}
最后,您需要一个起点,它定义了一个 mask 。最后一位扫描返回一个生成函数的表达式,并调用它。 将下面的放在最上面,当你在线尝试时,它会根据你的掩码生成一串数字。
mask
= ex:expression
{ return ex() }
示例运行:027n(5,9){4}n12{2,8}(2,4)
给出 0271568891222224
。
关于javascript - 帮助创建 peg.js 解析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5241264/
使用语法 start = b / a a = "4" "2" b = "4" 与 peg.js识别 4 但不识别 42 在这种情况下错误 “第 1 行,第 2 列:预期的输入结束,但找
我试图了解如何使用 PEG.js 在文本中进行简单的搜索/替换。当然,这不是解析器的预期用途,但无论如何我对这些语言背后的逻辑感到好奇,以产生一些搜索/替换。 我遇到的问题是很难积极定义某些定义的互补
扩展我之前的帖子,我还在写汉诺塔。在解释了如何在钉子上画环的绝妙解决方案之后,我仍然有一个问题,我已经摆弄了很长一段时间了。 这是我的 PegClass: namespace Towers_Of_Ha
我最近遇到了 PEG 解析器和 Guido van Rossum 的 article on PEG parsers以及如何构建它们。那篇文章讨论了“PEG”解析器,但在内部它看起来就像一个递归下降解析
我的同事 PaulS 问了我以下问题: 我正在为现有语言(SystemVerilog - IEEE 标准)编写一个解析器,并且该规范中有一条结构与此类似的规则: cover_point =
我写了一个 PEG 解析器生成器只是为了好玩(有时间我会在 NPM 上发布它),并认为在它上面添加一个随机短语生成器会很容易。这个想法是在给定语法的情况下自动获得正确的短语。所以我设置了以下规则来从每
我很喜欢使用 YARD: http://www.ootl.org/yard/ http://code.google.com/p/yardparser/ http://www.codeproject.c
我正在使用 rust-peg 实现类似 OCaml 的语言我的解析器有一个错误。 我定义了 if 语句语法,但它不起作用。 我猜测试用例输入被解析为 Apply(Apply(Apply(Apply(f
我想使用 Peg.js 来解析和验证我一直在使用正则表达式所做的事情,但我正在努力解决语法问题。 我的 Peg.js 程序是: start = (var / other) cr d:var {retu
我正在尝试使用pegjs创建一个解析器。我需要解析类似的内容: blah blah START Lorem ipsum dolor sit amet, consectetur adipiscing e
我目前正在编写PEG.js语法,并且希望它输出自定义错误。例如,我目前具有用于创建函数的这种结构。 //Function Declaration FUNCTION_DECLARATION = FUNC
我当前遇到的问题是我的代码无法解决钉子纸牌的不同变体。我的测试程序测试了 4 个简单的可解板。 (1步解法)上一步、下一步、左一步、右一步。我的代码毫无问题地解决了这些问题,并测试了无法解决的板。我遇
使用 https://github.com/JetBrains/Grammar-Kit如何不用左递归重写文法? grammar ::= exprs exprs::= (sum_expr (';')?)
我正在尝试解析逗号分隔的列表。为了简单起见,我只使用数字。这些表达式是有效的: (1,4,3) () (4) 我可以想到两种方法来做到这一点,我想知道为什么失败的例子不起作用。我相信它是正确的 BNF
我将如何在 Treetop 中做这样的事情? /.+?;/ 似乎唯一的方法是这样做: [^;]+ ';' 哪个有点丑......还有其他方式吗? .+? 似乎不起作用.. 最佳答案 默认情况下 PEG
我在定义允许两个标签(包括那些标签)之间的任何文本的表达式时遇到问题。 例子: #ifdef asdasdasdasdasdsasd asdasdasdasdasdasdasd asdasdasda
我有以下 peg.js 脚本: start = name* name = '** name ' var ws 'var:' vr:var ws 'len:' n:num? ws 'label:' lb
我正在尝试创建一个钉跳拼图,并且正在执行格式说明符,我意识到算法尚未完成,但有人可以解释为什么我的条件被忽略吗?即使列不止一列,它也会运行格式规范。例如,在钉跳益智游戏中,第一行之后的每一行的每个“+
我在 PEG.js 和匹配单词方面遇到问题。 它看起来像这样:Words = "stack"/"overflow"/"stackoverflow" - 当我尝试匹配“stackoverflow”时,它
编辑:您可以在此处关注进度:https://github.com/simple-updates/template 我正在使用 peg.js并尝试编写一些可以解释模板的东西,例如: hello {{ "
我是一名优秀的程序员,十分优秀!