这就是我正在做的:
c.scan(/[1-9]|1[0-2]/)
由于某些原因,它只返回1到9之间的数字,忽略了第二部分。我尝试了一点,似乎只有在1-9部分中排除1的情况下,该方法才会搜索10-12,例如,c.scan(/2-9|10-2/)就可以。原因何在?
附注:我知道这个方法缺少lookbehinds,也会搜索数字和“部分数字”。
发布于 2014-12-29 07:43:11
如有必要,请更改模式的顺序并添加单词边界。
c.scan(/\b(?:1[0-2]|[1-9])\b/)
首先使用|
之前的模式。因此,在我们的例子中,它匹配从10到12的所有数字。然后是下一个模式,也就是使用|
之后的模式,现在它匹配从1到9的所有剩余数字。请注意,这也将匹配59
中的9
。因此,我建议您将您的模式放在捕获或非捕获组中,并在该组之前和之后添加单词边界\b
(单词字符和非单词字符之间的匹配)。
DEMO
发布于 2014-12-29 07:43:02
|
从左到右匹配,右侧的第一部分(1
)始终与左侧匹配。反转它们:
c.scan(/1[0-2]|[1-9]/)
发布于 2014-12-29 16:50:52
这里有另一种方法,你可以考虑提取1到12之间的数字(假设这是你想做的):
c = '14 0 11x 15 003 y12'
c.scan(/\d+/).map(&:to_i).select { |n| (1..12).cover?(n) }
#=> [11, 3, 12]
我返回了一个整数数组,而不是字符串,我认为这可能会更有用,但如果您想要字符串:
c.scan(/\d+/).map { |s| s.to_i.to_s }
.select { |s| ['10', '11', '12', *'1'..'9'].include?(s) }
#=> ["11", "3", "12"]
与使用单个正则表达式相比,我看到了这种方法的几个优点:
https://stackoverflow.com/questions/27681764
复制相似问题