Ruby编程中,如何用正则表达式解决这个超奇怪的问题呢?
- 内容介绍
- 文章标签
- 相关推荐
本文共计312个文字,预计阅读时间需要2分钟。
我使用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上得到一个匹配,这是我的目标.
'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分钟。
我使用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上得到一个匹配,这是我的目标.
'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"]

