Преобразование экспоненты в число с плавающей точкой - PullRequest
3 голосов
/ 08 февраля 2012

Это мой код, пытающийся преобразовать второе поле строки из экспоненциального в float.

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

Кто-нибудь знает причину?

Ответы [ 6 ]

13 голосов
/ 08 февраля 2012

Простой способ заменить! Один простой пример:

value=str('6,0865000000e-01')
value2=value.replace(',', '.')
float(value2)
0.60865000000000002
11 голосов
/ 08 февраля 2012

Причина заключается в использовании запятой в 6,0865000000e-01.Это не будет работать, потому что float() не поддерживает локали.Подробнее см. PEP 331 .

Попробуйте locale.atof() или замените запятую точкой.

1 голос
/ 24 марта 2016

Просто бросая строку в число с плавающей точкой:

new_val = float('9.81E7')
0 голосов
/ 24 января 2019

Это работает для меня, попробуйте.

def remove_exponent(value):
    decial = value.split('e')
    ret_val = format(((float(decial[0]))*(10**int(decial[1]))), '.8f')
    return ret_val
0 голосов
/ 17 июня 2017

float является правильным , просто используйте format, чтобы отобразить его, как вы хотите, т.е.

print format(the_float, '.8f')
0 голосов
/ 24 декабря 2013

Я думаю, что это полезно для вас:

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)
...