将带有破折号的列表转换为数字

时间:2012-06-29 23:07:14

标签: python

我从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将破折号正确解析成数字?

1 个答案:

答案 0 :(得分:7)

看起来您正在创建的列表是1D但是当您尝试解析它时,您将其视为2D列表,它会尝试将每个元素中的每个字符转换为浮点数(因此在尝试时会抛出错误)做float('-'))。尝试使用以下内容替换该行以解决问题:

list2 = map(float, list1)

您还应该尝试在该行之前添加print list1,以确认该列表具有您认为的结构。