我使用Python 2.7.3我有以下功能:
def is2To4Numbers(q):
if re.match('[0-9]{2,4}',q):return True
else: return False
我试图将位数限制在2到4.但我得到了这些结果。
>>> is2To4Numbers('1235')
True
>>> is2To4Numbers('1')
False
>>> is2To4Numbers('12345')
True
>>> is2To4Numbers('1234567890')
True
我似乎无法获得正确的限制。我该怎么解决这个问题?除了使用{m,n}之外还有其他方法吗?或者我甚至正确使用{m,n}?
答案 0 :(得分:9)
你的正则表达式只查找大数字内存在的2到4位数字。加上这个:
'^[0-9]{2,4}$'
使用内置数值测试并添加大于和小于这样的检查可能要容易得多:
def is2To4Numbers(q):
try:
return 10 <= int(q) <= 9999
except:
return False
答案 1 :(得分:3)
如果你想在一个更大的字符串中搜索确切的2到4位数,因此不能使用^
和$
作为模式的一部分,那么你可以使用{{3 (?<!
)和负面预测(?!
):
import re
def is2To4Numbers(q):
return bool(re.search(r'''(?x) # verbose mode
(?<!\d) # not preceded by a digit
\d{2,4} # 2-to-4 digits
(?!\d) # not followed by a digit
''',q))
tests = ['1', '12', '123', '1234', '12345', 'foo12', '123bar']
for test in tests:
print('{t:6} => {r}'.format(t = test, r = is2To4Numbers(test)))
产量
1 => False
12 => True
123 => True
1234 => True
12345 => False
foo12 => True
123bar => True