加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Ruby和正则表达式的问题非常奇怪

发布时间:2020-12-17 01:23:01 所属栏目:百科 来源:网络整理
导读:我从string.scan和几个正则表达式测试人员那里获得了完全不同的结果…… 我只是想从字符串中抓取域名,这是最后一个字. 有问题的正则表达式: /([a-zA-Z0-9-]*.)*w{1,4}$/ 字符串(1个单行,在Ruby的运行时btw中验证) str = 'Show more results from softwar
我从string.scan和几个正则表达式测试人员那里获得了完全不同的结果……

我只是想从字符串中抓取域名,这是最后一个字.

有问题的正则表达式:

/([a-zA-Z0-9-]*.)*w{1,4}$/

字符串(1个单行,在Ruby的运行时btw中验证)

str = 'Show more results from software.informer.com'

工作正常,但在ruby….

irb(main):050:0> str.scan /([a-zA-Z0-9-]*.)*w{1,4}$/
=> [["informer."]]

我认为我会在software.informer.com上得到一个匹配,这是我的目标.

解决方法

它看起来不像你期望的结果多一个(特别是当正则表达式被锚定时).在这种情况下,没有理由使用扫描.

'Show more results from software.informer.com'[ /([a-zA-Z0-9-]*.)*w{1,4}$/ ]
#=> "software.informer.com"

如果您确实需要使用扫描(在这种情况下您显然需要删除锚点),您可以使用(?:)创建非捕获组.

'foo.bar.baz lala software.informer.com'.scan( /(?:[a-zA-Z0-9-]*.)*w{1,4}/ )
#=> ["foo.bar.baz","lala","software.informer.com"]

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读