Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?

2026-04-11 19:531阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计312个文字,预计阅读时间需要2分钟。

Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?

我使用string.scan和几个正则表达式测试员工信息,获得了完全不同的结果... 我只想从字符串中提取域名,这是最后一个字。有问题的正则表达式是:/(\w-?)*\.\w{1,4}$/。字符串(单行)

我从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上得到一个匹配,这是我的目标.

Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?

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

'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"]

本文共计312个文字,预计阅读时间需要2分钟。

Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?

我使用string.scan和几个正则表达式测试员工信息,获得了完全不同的结果... 我只想从字符串中提取域名,这是最后一个字。有问题的正则表达式是:/(\w-?)*\.\w{1,4}$/。字符串(单行)

我从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上得到一个匹配,这是我的目标.

Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?

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

'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"]