8

这是我的代码,试图将行的第二个字段从指数转换为浮点数。

outputrrd = processrrd.communicate()
(output, error) = outputrrd
output_lines = output.split('\n')
for line in output_lines:
    m = re.search(r"(.*): ", line)
    if m != None:
        felder = line.split(': ')
        epoch =  felder[0].strip(':')
        utc = epoch2normal(epoch).strip("\n")
        #print felder[1]
        data = float(felder[1])
        float_data = data * 10000000
        print float_data
        resultslist.append( utc + ' ' + hostname + ' ' +  float_data)

但是,程序因以下错误而停止:

File "/opt/omd/scripts/python/livestatus/rrdfetch-convert.py", line 156, in <module>
    data = float(felder[1])
ValueError: invalid literal for float(): 6,0865000000e-01

有谁知道原因?

4

7 回答 7

19

最简单的方法是更换!一个简单的例子:

value=str('6,0865000000e-01')
value2=value.replace(',', '.')
float(value2)
0.60865000000000002
于 2012-02-08T15:17:46.747 回答
11

原因是在6,0865000000e-01. 这不起作用,因为float()它不支持区域设置。有关详细信息,请参阅PEP 331

尝试locale.atof(),或用点替换逗号。

于 2012-02-08T15:01:25.750 回答
6

float正确的,只需使用format它来显示它,即:

print(format(the_float, '.8f'))
于 2017-06-17T10:08:31.233 回答
1

我认为它对你有用:

def remove_exponent(value):
    """
       >>>(Decimal('5E+3'))
       Decimal('5000.00000000')
    """
    decimal_places = 8
    max_digits = 16

    if isinstance(value, decimal.Decimal):
        context = decimal.getcontext().copy()
        context.prec = max_digits
        return "{0:f}".format(value.quantize(decimal.Decimal(".1") ** decimal_places, context=context))
    else:
        return "%.*f" % (decimal_places, value)
于 2013-12-24T11:46:37.410 回答
1

这对我有用,试试看。

def remove_exponent(value):
    decial = value.split('e')
    ret_val = format(((float(decial[0]))*(10**int(decial[1]))), '.8f')
    return ret_val
于 2019-01-24T12:24:18.887 回答
1

只需将字符串转换为浮点数:

new_val = float('9.81E7')
于 2016-03-24T10:19:15.197 回答
0

我在尝试将科学/指数表示法中的字符串转换为浮点数时遇到了类似的问题(如果太长也可能导致指数表示法)

num = '-8e-05'

def scientific_to_float(exponential):
  split_word = 'e'
  e_index = exponential.index('e')
  base = float(exponential[:e_index])
  exponent = float(exponential[e_index + 1:])
  float_number = base * (10 ** exponent)
  return float_number

scientific_to_float(num) # return -8e-05 float number
于 2021-10-19T09:30:52.983 回答