Extraer valor flotante / doble

¿Cómo extraigo un valor doble de una cadena usando expresiones regulares?

import re pattr = re.compile(???) x = pattr.match("4.5") 

Aquí está la manera fácil. No utilice expresiones regulares para los tipos incorporados.

 try: x = float( someString ) except ValueError, e: # someString was NOT floating-point, what now? 

Una perldoc perlretut :

 import re re_float = re.compile("""(?x) ^ [+-]?\ * # first, match an optional sign *and space* ( # then match integers or fp mantissas: \d+ # start out with a ... ( \.\d* # mantissa of the form ab 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 

Para extraer números de una cadena más grande:

 s = """4.5 abc -4.5 abc - 4.5 abc + .1e10 abc . abc 1.01e-2 abc 1.01e-.2 abc 123 abc .123""" print re.findall(r"[+-]? *(?:\d+(?:\.\d*)?|\.\d+)(?:[eE][+-]?\d+)?", s) # -> ['4.5', '-4.5', '- 4.5', '+ .1e10', ' 1.01e-2', # ' 1.01', '-.2', ' 123', ' .123'] 

Para los valores parse int y float (separador de puntos):

 re.findall( r'\d+\.*\d*', 'some 12 12.3 0 any text 0.8' ) 

resultado:

 ['12', '12.3', '0', '0.8'] 

Un flotador como expresión regular en fuerza bruta. Hay diferencias más pequeñas en la versión de JF Sebastian:

 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>