字符串变量myvar
可以具有以下值:
261.30 (NM) / 300.76 (MI) / 483.93 (KM)
952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)
我需要提取数字483.93
和1,763.61
。这些数字应转换为浮点数或四舍五入为整数。
这是我尝试过的:
mylar = "261.30 (NM) / 300.76 (MI) / 483.93 (KM)"
int(myvar[28:-8])
它在第一种情况下起作用(261.30 (NM) / 300.76 (MI) / 483.93 (KM)
)。但是在952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)
的情况下失败。有什么通用的解决方案吗?
答案 0 :(得分:2)
您可以使用此正则表达式检测字符串中的最后一个数字并将其放置在group1中,
([^ ]*)[^\d]*$
然后使用以下python代码,您可以将其转换为float或int。我将其转换为浮点数,因为它们是十进制值,但是您可以轻松地将它们转换为整数。
import re
arr = ['261.30 (NM) / 300.76 (MI) / 483.93 (KM)','952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)']
for s in arr:
val = re.search(r'([^ ]*)[^\d]*$', s)
floatval = float(re.sub(r',','',val.group(1)))
print('Float value: ' + str(floatval))
print('Int value: ' + str(int(floatval)))
打印
Float value: 483.93
Int value: 483
Float value: 1763.61
Int value: 1763
答案 1 :(得分:2)
具有单个re.search
功能,无需任何替换:
import re
myvar = '952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)'
num = re.search(r'\/\s+(\d+),?(\d+\.\d+)\s+\(KM\)', myvar)
if num:
num = float(num.group(1) + num.group(2))
print(num)
输出:
1763.61
答案 2 :(得分:2)
您也可以只使用split()
str1="261.30 (NM) / 300.76 (MI) / 483.93 (KM)"
last_num_string=str1.split('/')[2].split('(')[0]
last_num_float=float(last_num_string)
print(last_num_float)
答案 3 :(得分:1)
在这种情况下,我将创建一个值列表,然后从中提取任何一个值。
myvar2 = myvar.replace("/", "").replace(",", "")
myvar2 = myvar2.split()
# This gives a list like this: ["261.30","(NM)","300.76","(MI)","483.93","(KM)"]
myfloat = float(myvar[4]) # This will return 483.93 on the first string and 1,763.61 on the second.
答案 4 :(得分:1)
您可以使用正则表达式来做到这一点。
import re
target = '952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)'
regex = r'.* \(NM\) \/ .* \(MI\) \/ (.*) \(KM\)'
res_str = re.findall(regex, target)
float_str = res_str[0].replace(',', '')
result = float(float_str)
答案 5 :(得分:1)
import re
m="261.30 (NM) / 300.76 (MI) / 483.93 (KM)"
print(float(re.split('\/',re.sub(',','',m))[2][:-5]))
答案 6 :(得分:1)
由于值后跟(KM)
,因此可以使用正向前瞻:
\S+(?= \(KM\))
\S+
匹配1个以上非空格字符(?= \(KM\))
要检查右边的正向空间,是空格和(KM)例如:
regex = r"\S+(?= \(KM\))"
strings = ["261.30 (NM) / 300.76 (MI) / 483.93 (KM)", "952.27 (NM) / 1,096.09 (MI) / 1,763.61 (KM)"]
for s in strings:
matches = re.search(regex, s)
if matches:
print(float(matches.group().replace(',', '')))
这将为您提供:
483.93
1763.61