import re
re_float = re.compile("""(?x)
^
[+-]?\ * # first, match an optional sign *and space*
( # then match integers or f.p. mantissas:
\d+ # start out with a ...
(
\.\d* # mantissa of the form a.b or a.
)? # ? takes care of integers of the form a
|\.\d+ # mantissa of the form .b
)
([eE][+-]?\d+)? # finally, optionally match an exponent
$""")
m = re_float.match("4.5")
print m.group(0)
# -> 4.5
Для параметров синтаксиса и float (разделителя точек):
re.findall( r'\d+\.*\d*', 'some 12 12.3 0 any text 0.8' )
результат:
['12', '12.3', '0', '0.8']
Ответ 4
float как регулярное выражение в грубой силе. существуют меньшие отличия от версии Дж. Ф. Себастьяна:
import re
if __name__ == '__main__':
x = str(1.000e-123)
reFloat = r'(^[+-]?\d+(?:\.\d+)?(?:[eE][+-]\d+)?$)'
print re.match(reFloat,x)
>>> <_sre.SRE_Match object at 0x0054D3E0>