如何定位re.compile()
的整数范围,其中范围的限制是两个一般整数 a
和b
?
例如,假设我想要定位字符串,如:
foo_bar_8
foo_bar_12
即。最后的数字在范围内8-14
( a=8
, b=14
)。请注意,a
和b
是两个整数,数字位数可能不同。
但不是字符串:
foo_bar_15
foo_bar_4
foo_bar_20
(最后的数字不在8-14
范围内)
更一般地说,我有两个整数a
和b
,其中a
和b
的位数可能不同。如何在Python中的正则表达式中编码这样的通用范围?
答案 0 :(得分:5)
正则表达式处理字符串,句点。他们不知道一串字符对你来说是什么意思。
有时可以使用re.sub()
来提供意义,因为sub()
传递了一个函数,它可以实现您可以编程的任何含义。例如,
import re
def matcher(m):
digits = m.group()
print "matched", repr(digits), "at", m.span()
if 8 <= int(digits) <= 14:
print "OK!"
else:
print "rejected"
return digits # no change
s = "foo_bar_8 foo_bar_12 foo_bar_15 foo_bar_4 foo_bar_20"
re.sub("\d+", matcher, s)
打印:
matched '8' at (8, 9)
OK!
matched '12' at (18, 20)
OK!
matched '15' at (29, 31)
rejected
matched '4' at (40, 41)
rejected
matched '20' at (50, 52)
rejected
根据您想要做的事情,这可能非常容易 - 或者非常紧张; - )
答案 1 :(得分:2)
尝试以下表达式:
(?:[89]|1[01234])$
[89]
匹配8
或9
,1[01234]
匹配1
后跟0
,1
,{{1} }},2
或3
。
4
匹配字符串的结尾。