我从CSV文件中创建了一个列表。它看起来像这样:
['18', '29', '0'...'0', '-14', '9']
它在开头有一个文本元素,我弹出。现在,Python不能使用列表元素和正确的数字一起使用。例如,每当我尝试将元素解析为浮点数时,我都会收到错误消息:
ValueError: could not convert string to float: -
我的代码如下所示:
list2=[[float(column) for column in row] for row in list1]
或者这个:
list2 = [map(float, x) for x in list1]
两个版本都会产生相同的结果。如果我尝试不同的数据类型,我会收到如下消息:
ValueError: invalid literal for int() with base 10: '-'
有谁能告诉我如何让Python将破折号正确解析成数字?
答案 0 :(得分:7)
看起来您正在创建的列表是1D但是当您尝试解析它时,您将其视为2D列表,它会尝试将每个元素中的每个字符转换为浮点数(因此在尝试时会抛出错误)做float('-')
)。尝试使用以下内容替换该行以解决问题:
list2 = map(float, list1)
您还应该尝试在该行之前添加print list1
,以确认该列表具有您认为的结构。