regex 如何从字符串中提取浮点数[duplicate]

b09cbbtk  于 2022-12-14  发布在  其他
关注(0)|答案(7)|浏览(169)

此问题在此处已有答案

Extract float/double value(5个答案)
八年前就关门了。
我有一些类似于Current Level: 13.4 db.的字符串,我想只提取浮点数。我说浮点数而不是小数,因为有时它是整数。RegEx能做到这一点吗?或者有更好的方法吗?

xbp102n0

xbp102n01#

如果你的浮点数总是用十进制表示,比如

>>> 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
zysjyyx4

zysjyyx42#

你可能会想试试这样的方法,它涵盖了所有的基础,包括不依赖于数字后的空格:

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

a0zr77ik3#

Python docs提供了一个答案,其中包括+/-、和指数符号。

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+)?
z2acfund

z2acfund4#

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)

kgsdhlau

kgsdhlau5#

可以使用下面的正则表达式从字符串中获取整数和浮点值:

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

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

谢谢雷克斯

kqhtkvqz

kqhtkvqz6#

我想你会在我下面的回答中发现有趣的东西,我对以前的一个类似的问题做了回答:
https://stackoverflow.com/q/5929469/551449
在这个答案中,我提出了一个模式,允许正则表达式捕捉任何类型的数字,因为我没有其他东西可以添加到它,我认为它是相当完整的

wmvff8tz

wmvff8tz7#

另一种可能更容易理解的方法是简单的类型转换。我添加了一个替换函数来覆盖人们可能输入欧洲小数的示例:

>>> 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。而且,它假设人们将在单词之间输入空格。这不是其他语言的情况,如中文。

相关问题