Python来验证字符串是否代表一个合法的数字

经常会碰到的场景,从文件中读取的或用户输入获得的一个字符串,看是否是合法的数字格式。 可以有两个方案。

方案一: 使用最简单的也是最Pythonic的"鸭子走路"

>>> def legal_numbers(s):
...     try:
...         float(s)
...     except ValueError:
...         return False
...     else:
...         return True
...
>>> legal_numbers('OK1234')
False
>>> legal_numbers('123456')
True
>>> legal_numbers('12.345')
True
>>> legal_numbers('-1.2e3')
True
>>> legal_numbers('-12345')
True
>>>

方案二: 使用正则表达式来完全匹配合法数字

>>> import re
>>> num_re = re.compile(r'^[-+]?([0-9]+\.?[0-9]*|\.[0-9]+)([eE][-+]?[0-9]+)?$')
>>> def legal_numbers(s):
...     return bool(num_re.match(s))
...
>>> legal_numbers('OK1234')
False
>>> legal_numbers('123456')
True
>>> legal_numbers('12.345')
True
>>> legal_numbers('-1.2e3')
True
>>> legal_numbers('+3.141')
True

从上面来看,显然第一种方法要简单并更符合Pythonic的精神! 

猜你喜欢

转载自blog.csdn.net/Jerry_1126/article/details/81175491