134

に似た文字列がいくつかありCurrent Level: 13.4 db.、浮動小数点数だけを抽出したいと思います。私はフローティングと言い、10 進数ではなく、全体であることがあります。正規表現はこれを行うことができますか、それともより良い方法がありますか?

4

7 に答える 7

269

float が常に 10 進表記で表される場合、次のようになります。

>>> 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
        
于 2011-01-16T02:16:13.740 に答える
77

数字の後の空白に頼らないことを含め、すべてのベースをカバーするこのようなものを試してみたいと思うかもしれません:

>>> 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")
于 2011-01-16T02:46:06.990 に答える
10
re.findall(r"[-+]?\d*\.?\d+|\d+", "Current Level: -13.2 db or 14.2 or 3")

上記のように、本当にうまくいきます!ただし、1つの提案:

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

負の int 値も返します (この文字列の末尾にある -3 など)。

于 2011-11-25T10:24:12.263 に答える
7

次の正規表現を使用して、文字列から整数値と浮動小数点値を取得できます。

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

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

ありがとうレックス

于 2014-05-21T15:14:00.647 に答える
3

以前の同様の質問に対して行った次の回答で、興味深いものを見つけることができると思います。

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

この回答では、正規表現があらゆる種類の数値をキャッチできるようにするパターンを提案しました。これに追加するものは他にないので、かなり完成したと思います

于 2011-11-25T11:08:58.027 に答える
2

より読みやすい別のアプローチは、単純な型変換です。人々がヨーロッパの小数を入力する可能性がある場合をカバーするために、置換関数を追加しました。

>>> 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 に変換されます。また、単語間に空白を入れて入力することを前提としています。これは、中国語などの他の言語には当てはまりません。

于 2011-01-16T02:40:40.673 に答える