繁体   English   中英

当前面有数字时递归匹配每个非数字字符

[英]Recursively matching each non-digit characters when preceded by a digit

我正在尝试匹配每个直接以数字开头的非数字字符。 这个想法是用数字0替换O

例如:

58OO
1O1O
2OOOm
FOO
O

所需的 output 是

5800
1010
2000m
FOO
O

我尝试在我问的上一个问题中使用答案,但我没有设法使正则表达式适应我的目的。

这是我尝试的一些正则表达式,但没有成功(并且有充分的理由): (\d\K(?>O|(?1)))\d\K(?:O|(?R))

与递归无关,只需使用一个简单的while循环:

import re

strings = ["58OO", "1O1O", "2OOOm", "FOO", "O"]

pattern = re.compile(r'(?<=\d)O')

for item in strings:
    while True:
        olditem = item
        item = pattern.sub("0", item)
        if item == olditem:
            # no replacement was made
            break

    print(item)

这产生

5800
1010
2000m
FOO
O

是时候安装PyPi 正则表达式模块了:

import regex
texts = ["58OO", "1O1O", "2OOOm", "FOO", "O"]
for text in texts:
  print( regex.sub(r'(?<=\d+O*)O', '0', text) )

Output:

5800
1010
2000m
FOO
O

(?<=\d+O*)O O匹配之前有数字和任意数量的O的 O 。

一个简单的潜艇就足够了。

python解释器的示例:

>>> import re
>>> raw = '''
58OO
O1O1O
2OOOm
FOO
O
'''
>>>
>>> print(re.sub(r'(\d+)(O+)', lambda m: m.group(1) +  '0' * len(m.group(2)), raw))

5800
O1010
2000m
FOO
O

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM