Вопрос-Ответ

How to extract a floating number from a string [duplicate]

Как извлечь плавающее число из строки

У меня есть несколько строк, похожих на Current Level: 13.4 db., и я хотел бы извлечь только число с плавающей запятой. Я говорю "с плавающей запятой", а не "десятичное", поскольку иногда оно бывает целым. Может ли регулярное выражение сделать это или есть способ получше?

Переведено автоматически
Ответ 1

Если ваше число с плавающей запятой всегда выражается в десятичной системе счисления, то что-то вроде

>>> import re
>>> re.findall("\d+\.\d+", "Current Level: 13.4db.")
['13.4']

может быть достаточно.

Более надежной версией было бы:

>>> re.findall(r"[-+]?(?:\d*\.*\d+)", "Current Level: -13.2db or 14.2 or 3")
['-13.2', '14.2', '3']

Если вы хотите проверить вводимые пользователем данные, вы также можете проверить наличие числа с плавающей запятой, перейдя непосредственно к нему:

user_input = "Current Level: 1e100 db"
for token in user_input.split():
try:
# if this succeeds, you have your (first) float
print(float(token), "is a float")
except ValueError:
print(token, "is something else")

# => Would print ...
#
# Current is something else
# Level: is something else
# 1e+100 is a float
# db is something else

Ответ 2

Возможно, вам захочется попробовать что-то подобное, что охватывает все основы, в том числе не полагаться на пробелы после числа:

>>> import re
>>> numeric_const_pattern = r"""
... [-+]? # optional sign
... (?:
... (?: \d* \. \d+ ) # .1 .12 .123 etc 9.1 etc 98.1 etc
... |
... (?: \d+ \.? ) # 1. 12. 123. etc 1 12 123 etc
... )
... # followed by optional exponent part if desired
... (?: [Ee] [+-]? \d+ ) ?
... """

>>> rx = re.compile(numeric_const_pattern, re.VERBOSE)
>>> rx.findall(".1 .12 9.1 98.1 1. 12. 1 12")
['.1', '.12', '9.1', '98.1', '1.', '12.', '1', '12']
>>> rx.findall("-1 +1 2e9 +2E+09 -2e-9")
['-1', '+1', '2e9', '+2E+09', '-2e-9']
>>> rx.findall("current level: -2.03e+99db")
['-2.03e+99']
>>>

Для упрощения копирования-вставки:

numeric_const_pattern = '[-+]? (?: (?: \d* \. \d+ ) | (?: \d+ \.? ) )(?: [Ee] [+-]? \d+ ) ?'
rx = re.compile(numeric_const_pattern, re.VERBOSE)
rx.findall("Some example: Jr. it. was .23 between 2.3 and 42.31 seconds")
Ответ 3

Вдокументах Python есть ответ, который охватывает + / - и обозначение экспоненты

scanf() Token      Regular Expression
%e, %E, %f, %g [-+]?(\d+(\.\d*)?|\.\d+)([eE][-+]?\d+)?
%i [-+]?(0[xX][\dA-Fa-f]+|0[0-7]*|\d+)

Это регулярное выражение не поддерживает международные форматы, где запятая используется в качестве символа-разделителя между целой и дробной частями (3,14159).
В этом случае замените all \. на [.,] в приведенном выше регулярном выражении с плавающей запятой.

                        Regular Expression
International float [-+]?(\d+([.,]\d*)?|[.,]\d+)([eE][-+]?\d+)?
Ответ 4
re.findall(r"[-+]?\d*\.?\d+|\d+", "Current Level: -13.2 db or 14.2 or 3")

как описано выше, работает действительно хорошо!
Однако есть одно предложение:

re.findall(r"[-+]?\d*\.?\d+|[-+]?\d+", "Current Level: -13.2 db or 14.2 or 3 or -3")

также вернет отрицательные значения int (например, -3 в конце этой строки)

python regex