文字列からフローティング番号を抽出する方法[複製
-
11-10-2019 - |
質問
この質問にはすでに答えがあります:
- フロート/ダブル値を抽出します 4つの回答
私は同じようないくつかの文字列を持っています 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")
上記のように、本当にうまく機能します!ただし、1つの提案:
re.findall(r"[-+]?\d*\.?\d+|[-+]?\d+", "Current Level: -13.2 db or 14.2 or 3 or -3")
また、負のINT値を返します(この文字列の最後の-3のように)
次のRegexを使用して、文字列から整数と浮動的な値を取得できます。
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
この答えでは、regexがあらゆる種類の数をキャッチできるようにするパターンを提案しました。
より読みやすい別のアプローチは、シンプルなタイプ変換です。人々がヨーロッパの小数に入る可能性のあるインスタンスをカバーするための交換機能を追加しました。
>>> 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に変換されます。また、人々は単語間で白人を入力することを前提としています。これは、中国語などの他の言語には当てはまりません。