gpt4 book ai didi

ruby - 如何在不影响上下文的情况下使用 RegEx 根据上下文替换项目

转载 作者:太空宇宙 更新时间:2023-11-03 18:25:43 25 4
gpt4 key购买 nike

我正在使用 Ruby 编写一个正则表达式,我需要能够删除出现在括号之间的任何冒号。我知道我可以使用

"This is a (string :)".sub!(/\([^\)]*:/, '') 

要做到这一点,但问题是这个函数也会一起删除上下文。有什么方法可以指定我只希望它删除冒号而不是整个匹配表达式吗?

最佳答案

因此,一些正则表达式引擎支持所谓的前瞻和后视匹配,它们将匹配但不消耗字符。 Ruby 确实支持向前看,但不支持向后看(这更难以高效的方式做到),这意味着您可以很容易地坚持使用 sub 并删除右括号之前的冒号, 但只是不确保它在左括号之后:

string = 'This is a (string :)'
string.sub /:(?=\))/, ''
# => 'This is a (string )'

另一种方法是使用子模式捕获(当您在正则表达式中使用分组时会自动发生)来重建没有不需要的部分的字符串,在本例中为冒号:

string.sub /(\([^:]+):\)/, '\1)'

\1 是对第一组中匹配内容的反向引用,由未转义的括号分隔。您可以在这里看到,我没有费心在第二组中捕获右括号,而是选择简单地将其包含在替换中。这在这种情况下效果很好,因为它不会改变,但如果您不知道冒号将出现在括号内内容的末尾,您将需要第二组:

string.sub /(\([^:]+):([^)]+\))/, '\1\2'

关于ruby - 如何在不影响上下文的情况下使用 RegEx 根据上下文替换项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11420189/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com