- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Raku 2020.10。
根据此页面,https://docs.raku.org/language/regexes#Longest_alternation:_| , "|"或带引号的列表是最长的匹配项。
> say "youtube" ~~ / < you tube > /
「you」 # expected "tube" to win the match
> say "youtube" ~~ / you | tube /
「you」 # expected "tube" to win the match
> say "youtube" ~~ / tube | you /
「you」 # expected "tube" to win the match
现在尝试“||”而不是“|”:
> say "tubeyou" ~~ / you || tube /
「tube」 # longest match or first match?
> say "youtube" ~~ / you || tube /
「you」 # first match?
现在尝试网页示例:
> say 'food' ~~ / f | fo | foo | food /
「food」 # works as expected
> say 'foodtubes' ~~ / f | fo | foo | food | tubes /
「food」 # expected "tubes" (5 chars) to win
> say 'foodtubes' ~~ / tubes | f | fo | foo | food /
「food」
> say 'foodtubes' ~~ / dt /
「dt」
> say 'foodtubes' ~~ / dt | food /
「food」
> say 'foodtubes' ~~ / dt | food | tubes /
「food」
看起来像带有“|”的匹配引擎在第一场有点长的成功比赛后退出。或者我做错了什么?
最佳答案
(这个答案建立在@donaldh 在评论中已经说过的内容之上)。
这是一个非常好的问题,因为它涉及的问题经常让人们对正则表达式如何搜索字符串感到困惑:从根本上来说正则表达式 一次搜索一个字符并返回第一个匹配项 它发现。您可以修改此行为(例如,环顾考虑其他字符;多个标志使正则表达式返回多个结果)。但是,如果您从对 regex 默认情况下的行为方式的基本了解开始,许多这些问题就会变得更加清晰。
因此,让我们将其应用于示例的一个轻微变体:
> `youtube' ~~ / you | ..| tube /
「you」
以下是正则表达式引擎如何看待它(在高级/简化术语中),逐个字符:
pos:0 youtube
^
branch 1 wants 'y'. Match!
branch 2 wants . (aka, anything). Match!
branch 3 wants 't' No match :(
pos:1 youtube
^
branch 1 wants 'o'. Match!
branch 2 wants . Match!
branch 2 completed with a length of 2
pos:2 youtube
^
branch 1 wants 'u'. Match!
branch 1 completed with a length of 3
...all branches completed, and 2 matches found. Return the longest match found.
「you」
这种逻辑的结果是,与往常一样,正则表达式返回字符串中的第一个匹配项(或者更具体地说,从字符串中最早位置开始的匹配项)。
|
的行为当多场比赛在同一地点开始时开始。当这种情况发生时,
|
意味着我们得到最长的匹配。
'youtube' ~~ / you | tube /
,我们永远不会有多个匹配从同一个地方开始,所以我们永远不需要依赖
|
的行为。 . (我们确实在字符串中有多个匹配项,您可以通过全局搜索看到:
'youtube' ~~ m:g/ you | tube /
)
('youtube' ~~ m:g/ you | tube /).sort(*.chars).tail
关于regex - raku:最长的比赛不做最长的比赛,但在第一场比赛后退出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66204127/
虽然总是可以使用 mixin 或方法覆盖来修改 Bool 强制转换,但默认情况下哪些值被认为是真值,哪些值被认为是假值? 注意:这个问题是 asked previously ,但不幸的是它太旧了,它的
也许我遗漏了一些东西,但我想知道这段代码是否有充分的理由 编译 role L { method do-l (Int, Int --> Int ) { ... } } class A does L
FAQ:在 Raku 中如何检查列表是否为空? 是否有比以下更惯用的方法: my @l = (); say @l.elems == 0; say @l == (); say @l.Bool; doc
FAQ:在 Raku 中,如何从列表中删除重复项以仅获取唯一值? my $arr = [1, 2, 3, 2, 3, 1, 1, 0]; # desired output [1, 2, 3, 0] 最
我使用 Raku 进行一些计算,因为它有很好的数字类型。但是,我在使用“.raku”时遇到问题 say (1/6+1/6).raku # 我们得到这个。然而, say (1/10+1/10).raku
常见问题解答:在 Raku 中,如何将字符串转换为十六进制的字节列表(即十六进制解码器) 目前,我有: say "I ❤ 🦋".encode.list.map(*.base(16)); # (49
在 1990 年代和 2000 年代,编程语言爱好者几乎没有讨论过分隔延续的话题。它最近重新成为编程语言讨论中的一个主要问题。 我希望有人至少可以权威地说出 Rakudo 背后的延续(与 Raku 相
我选择在 Perl 6 中重新设计我之前代码的一部分,在这种情况下是一个棋盘。前两个类运行良好(或者至少工作正常,我知道的很少,我无法确定它们的正确性) ,但我坚持第三。这是代码: #!/home/h
如何重现数组的每个元素 x 次? 例如 for my @a=;和 x=5 ,结果应该是这样的 (blu blu blu blu blu red red red red red) 我想出了这个 say
我正在尝试使用一个变量并在一个步骤中为其分配一个表达式: 给定的(示例)代码 my @l=; my $i=0; while $i ; my $i=0; say @l[$i =~ ($i+1) * 2]
我想连续打印偶数,但我不能。 use Terminal::ANSIColor; # Wanna print even numbers in red for { $_ %2 == 0 ?? say c
目前(截至 2020 年 8 月)Rakudo 不在编译时对函数的返回值进行类型检查;也就是说,它不提供函数满足其返回约束的静态保证。具体来说,以下两个函数都编译为 Raku: sub get-int
自从我上次更新我在 Raku 生态系统中的一个模块以来已经有一段时间了。我需要更新中央注册表文件/存储库还是会自动检测到更新? 最佳答案 修改版本号后,我等了一个小时左右,然后 zef可以安装模块 -
有人能告诉我如何在正在执行的 Raku 脚本中找到脚本的路径吗? 我正在 Raku 中寻找与此 Perl 代码等效的代码: $path=abs_path($0); 最佳答案 使用 $*PROGRAM见
Raku的正则表达式有两种交替形式:|和||。有什么区别 ? say 'foobar' ~~ / foo || foobar / # 「foo」 say 'foobar' ~~ / foo | fo
我故意避免使用术语 defined因为一个变量很可能有一个定义的值,但 .defined方法将返回 false(例如,失败)。 有什么方法可以确定变量是否已为其设置了值? my $foo; say $
我从/path/to/data 运行/home/foo/bar.p6 并显示“Segmentation fault (core dumped)” 我在/var/crash 或我的主目录或当前工作目录中
在 cli 上,在 linux 中,cp -p保留文件上修改/访问的时间戳。是否可以直接在 Raku 中执行相同操作? Rosetta 示例使用 Nativecall,它可以通过系统调用来完成,但看起
我想重用 token parameter来自 Perl6::Grammar在我的自定义俚语中添加“自定义参数”参数不带 cargo 培养 . 我的意思是说: my $main-grammar = $*
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 去年关闭。 Improve this questio
我是一名优秀的程序员,十分优秀!