这个问题在这里已经有一个答案:

我有很多类似于 Current Level: 13.4 db. 我想仅提取浮点数。我说浮动而不是十进制,因为有时是整体。 Regex可以做到这一点,还是有更好的方法?

有帮助吗?

解决方案

如果您的浮子总是以小数为单位表示

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

可能就足够了。

更强大的版本将是:

>>> re.findall(r"[-+]?\d*\.\d+|\d+", "Current Level: -13.2 db 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

其他提示

您可能想尝试这样的事情,以涵盖所有基础,包括在数字之后不依赖空格:

>>> 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")

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)。在这种情况下,替换全部 \.[.,] 在上面的浮点正则。

                        Regular Expression
International float     [-+]?(\d+([.,]\d*)?|[.,]\d+)([eE][-+]?\d+)?
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)

您可以使用以下正则拨号从字符串获取整数和浮动值:

re.findall(r'[\d\.\d]+', 'hello -34 42 +34.478m 88 cricket -44.3')

['34', '42', '34.478', '88', '44.3']

谢谢雷克斯

我认为您在以下我为以前的类似问题所做的以下答案中找到有趣的东西:

https://stackoverflow.com/q/5929469/551449

在这个答案中,我提出了一种模式,该模式允许正则抓住任何形式的数字,并且由于我没有其他要添加的数字,所以我认为它是相当完整的

可能更可读性的另一种方法是简单的类型转换。我添加了一个替代功能,以涵盖人们可能进入欧洲小数的实例:

>>> for possibility in "Current Level: -13.2 db or 14,2 or 3".split():
...     try:
...         str(float(possibility.replace(',', '.')))
...     except ValueError:
...         pass
'-13.2'
'14.2'
'3.0'

但是,这也有缺点。如果某人在“ 1,000”中类型,则将转换为1。此外,它假设人们将在单词之间使用空格输入。其他语言(例如中文)并非如此。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top