- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试用 JavaScript 编写一个词法分析器来查找简单的特定领域语言的标记。我从一个简单的实现开始,它只是尝试匹配一行中当前位置的后续正则表达式,以确定它是否匹配某种标记格式并接受它。
问题是,当这样的正则表达式中的某些内容不匹配时,整个正则表达式都会失败,所以我不知道究竟是哪个字符导致它失败。
有没有办法找出导致正则表达式失败的字符串中的位置?
INB4:我不是在询问调试我的正则表达式并验证其正确性。它已经是正确的,匹配正确的字符串并丢弃不正确的字符串。我只想以编程方式知道正则表达式停止匹配的确切位置,找出用户输入中不正确的字符的位置,以及其中有多少是好的。
有没有办法只用简单的正则表达式而不是继续实现一个成熟的有限状态自动机?
最佳答案
简答
There is no such thing as a "position in the string that causes the regular expression to fail".
At which token in the regex did the engine become unable to match the string?
the position in the string which caused the regular expression to fail
的问题是颠倒的。当引擎用左手向下移动字符串并用右手向下移动模式时,一个匹配六个字符的正则表达式标记可以稍后,由于量词和回溯,在下一个匹配零个字符 - 或扩展以匹配十。
At which token in the regex did the engine become unable to match the string?
^\w+\d+$
和字符串
abc132z
.
\w+
实际上可以匹配整个字符串。然而,整个正则表达式都失败了。说正则表达式在字符串末尾失败是否有意义?我不这么认为。考虑一下。
\w+
将匹配
abc132z
.然后引擎前进到下一个 token :
\d+
.在这个阶段,引擎在字符串中回溯,逐渐让
\w+
放弃
2z
(因此
\w+
现在只对应于
abc13
),允许
\d+
匹配
2
.
$
断言失败,因为
z
离开了。引擎回溯,让
\w+
,放弃
3
字符,然后是
1
(因此
\w+
现在只对应于
abc
),最终允许
\d+
匹配
132
.在每一步,引擎都会尝试
$
断言和失败。根据引擎内部结构,可能会发生更多回溯:
\d+
将再次放弃 2 和 3,然后
\w+
将放弃c和b。当引擎最终放弃时,
\w+
仅匹配初始
a
.你能说正则表达式“在“3”上失败了吗?在“b”上?
$
上失败了。 ,因为它是我们无法添加到匹配中的第一个标记。请记住,还有其他方法可以证明这一点。
At which token in the regex did the engine become unable to match the string?
^(?:(?=(\w+)))?(?:(?=(\w+\d+)))?(?:(?=(\w+\d+$)))?.
^(?=(\w+))?(?=(\w+\d+))?(?=(\w+\d+$))?.
\w+
token \w+\d+
,因此,它会逐步测试 \d+
token \w+\d+$
,因此,它会逐步测试 $
token abc123a
),您可以说
$
导致失败。如果设置了组 1 但未设置组 2(如
abc
),您可以说
\d+
导致失败。
关于javascript - 找出正则表达式失败的位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23839481/
我有一个加号/减号按钮,希望用户不能选择超过 20 个但不知道如何让它工作。我尝试使用 min="1"max="5 属性,但它们不起作用。这是我的代码和一个 fiddle 链接。https://jsf
我正在尝试复制顶部底部图,如示例 here但它没有正确渲染(紫色系列有 +ve 和 -ve 值,绿色为负值)留下杂乱的人工制品。我也在努力创建一个玩具示例来复制这个问题,所以我希望尽管我缺乏数据,但有
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 6 年前。 社区去年审查了是
这个问题在这里已经有了答案: Adding two positive integers gives negative answer.Why? (4 个答案) 关闭 5 年前。 我遇到了一个奇怪的问题
有谁知道如何将字符串值类型 -4,5 或 5,4 转换为 double -4.5 或 5.4? 最佳答案 只需使用 Double.parseDouble(Locale, String); 糟糕,我很困
我正在尝试根据 TextBlob 分类插入一个仅包含“正”或“负”字符串的新数据框列:对于我的 df 的第一行,结果是 ( pos , 0.75, 0.2499999999999997)我想要' 正
我对 VBA 非常陌生,无法理解如何在一个循环中完成 2 个任务。我非常感谢您的帮助。 我已经能够根据第 3 列中的数据更改第 2 列中的数值,但我不明白如何将负值的字体更改为红色。 表格的大小每月都
欢迎, 我正在使用 jquery 通过 POST 发送表单。 这就是我获得值(value)的方式。 var mytext = $("#textareaid").val(); var dataStrin
double d = 0; // random decimal value with it's integral part within the range of Int32 and always p
我有这个字符串: var a='abc123#xyz123'; 我想构建 2 个正则表达式替换函数: 1) 用 '*' 替换所有确实有 future '#'的字符(不包括'#') 所以结果应该是这样的
我正在使用 DialogFragment。当用户从 Gmail 平板电脑应用程序的屏幕与下面示例图片中的编辑文本进行交互时,我希望正面和负面按钮保持在键盘上方。 在我的尝试中不起作用,这是我的 Dia
从组装艺术一书中,我复制了这句话: In the two’s complement system, the H.O. bit of a number is a sign bit. If the H.O
是否有更好更优雅的方法来实现下面的简单代码(diffYear、A 和 B 是数字): diffYear = yearA - yearB; if (diffYear == 0) { A = B
我正在设计一种语言,并尝试确定 true 应该是 0x01 还是 0xFF。显然,所有非零值都将转换为 true,但我正在尝试确定确切的内部表示。 每种选择的优点和缺点是什么? 最佳答案 没关系,只要
在我的 dialogfragment 类的 OnCreateDialog 中,我正在这样做: AlertDialog.Builder builder = new AlertDialog.Builder
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda usin
我偶然发现了一个奇怪的 NSDecimalNumber 行为:对于某些值,调用 integerValue、longValue、longLongValue 等,返回意想不到的值(value)。示例: l
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda using
我有这个正则表达式来测试用户输入是否有效: value.length === 0 || value === '-' || (!isNaN(parseFloat(value)) && /^-?\d+\.
我想用高斯混合模型拟合数据集,数据集包含大约 120k 个样本,每个样本有大约 130 个维度。当我使用 matlab 执行此操作时,我运行脚本(簇号为 1000): gm = fitgmdist(d
我是一名优秀的程序员,十分优秀!