Питон. ValueError не смог преобразовать строку в число с плавающей запятой:

Я пытаюсь получить среднее число чисел в указанном столбце в текстовом файле. Я получаю сообщение об ошибке, что python не может преобразовать строку в число с плавающей запятой, хотя я не вижу, где я мог бы передать недопустимую строку.

def avg_col(f, col, delim=None, nhr=0):
    """
    file, int, str, int -> float

    Produces average of data stored in column col of file f

    Requires: file has nhr header rows of data; data is separated by delim

    >>> test_file = StringIO('0.0, 3.5, 2.0, 5.8, 2.1')
    >>> avg_col(test_file, 2, ',', 0)
    2.0

    >>> test_file = StringIO('0.0, 3.5, 2.0, 5.8, 2.1')
    >>> avg_col(test_file, 3, ',', 0)
    5.8
    """
    total = 0 
    count = 0


    skip_rows(f, nhr)
    for line in f: 
        if line.strip() != '':
            data = line.split(delim)
            col_data = data[col]
            total = sum_data(col_data) + total
            count = len(col_data) + count 
    return total / count

def sum_data(lod):
    '''
    (listof str) -> Real 

    Consume a list of string-data in a file and produce the sum

    >>> sum_data(['0'])
    0.0
    >>> sum_data(['1.5'])
    1.5

    '''
    data_sum = 0
    for number in lod: 
        data_sum = data_sum + float(number)
    return data_sum

person Kyle Dewhurst    schedule 26.01.2015    source источник
comment
Вам нужно поделиться полной трассировкой, и если вы можете предоставить некоторые примеры данных, которые воспроизводят исключение, это будет гораздо полезнее, чем просто опубликованный вами код.   -  person Martijn Pieters    schedule 26.01.2015


Ответы (1)


Вы передаете одну строку в sum_lod():

data = line.split(delim)
col_data = data[col]
total = sum_data(col_data) + total

data — это список строк, data[col] — это один элемент.

sum_data(), с другой стороны, ожидает iterable:

def sum_data(lod):
    # ...
    for number in lod: 

Итерация по числу дает вам отдельные символы:

>>> for element in '5.8':
...     print element
... 
5
.
8

Попытка преобразовать каждый элемент такой строки может легко привести к тому, что вы попытаетесь преобразовать символы, которые не являются числами, в число с плавающей запятой:

>>> float('.')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: could not convert string to float: .

Либо передайте список строк:

total += sum_data([col_data])
count += 1

или просто используйте float() для одного элемента, который у вас есть:

total += float(col_data)
count += 1
person Martijn Pieters    schedule 26.01.2015