首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >由三个大写字母限定的匹配小写字母

由三个大写字母限定的匹配小写字母
EN

Stack Overflow用户
提问于 2013-02-05 11:09:51
回答 3查看 426关注 0票数 0

我正在尝试查找每个边恰好被三个大写字符包围的小写字符的所有实例。然后,我想打印此模式的每个匹配项。这是python挑战赛中的一个挑战赛。这就是我所拥有的:

代码语言:javascript
运行
复制
contents = "XXXiXXXjXXX"
contents.scan(/[^A-Z]*[A-Z]{3}[a-z][A-Z]{3}[^A-Z]*/) { |i| print i[3] }

当它应该打印"ij"时,它只打印"i"。我的正则表达式有什么问题?

EN

回答 3

Stack Overflow用户

发布于 2013-02-05 11:35:39

有几件事是错的,解释什么是错的是不切实际的。

如果您不需要使用单个正则表达式来完成此操作,这里有一种简单的方法:

代码语言:javascript
运行
复制
puts " #{contents} ".split(/[A-Z]{3}/).&(("a".."z").to_a).join
票数 0
EN

Stack Overflow用户

发布于 2013-02-05 12:13:30

两件事。

  • Your [^A-Z]*

do do

  • 扫描指针第一次前进超过完全匹配,这就是它不会拾取‘j’的原因。

一个有点复杂的lookaround解决方案:

代码语言:javascript
运行
复制
re = /
  (?<=[A-Z]{3}) # 3 uppers behind
  (?<![A-Z]{4}) # but not 4
  [a-z] # one lower
  (?=[A-Z]{3}) # 3 uppers ahead
  (?![A-Z]{4}) # but not 4
/x

'XXXiXXXjXXX'.scan re
#=> ["i", "j"]
票数 0
EN

Stack Overflow用户

发布于 2013-02-05 11:15:46

如果您删除了前/后条件,导致它不匹配,那么正则表达式将起作用。然后,您应该在要提取的值周围添加括号作为捕获组,如下所示:

代码语言:javascript
运行
复制
match = contents.match(/[A-Z]{3}([a-z])[A-Z]{3}/)
match[1] if match
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14699559

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档