繁体   English   中英

如何将列表列表中的所有字符串转换为浮点数

[英]How to convert all the strings in a list of a list to floats

我已使用以下代码打开一个excel文件,以创建excel文件每一行的列表:

import csv
with open("csvfile.csv", "rb") as f:
    lines = list(csv.reader(f))

>>> lines
[['0', '23.345', '-122.456'], ['1', '12.546', '-118.987'] ['2', '67.435', '-104.112']]

我确实希望将excel文件的每一行的列表都保留在更大的列表中,但是我希望每个元素都是浮点数而不是字符串。 我必须进行哪些更改?

[[0, 23.345, -122.456], [1, 12.546, -118.987], [2, 67.435, -104.112]]

您可以在列表列表上使用嵌套列表推导

>>> my_list = [['0', '23.345', '-122.456'], ['1', '12.546', '-118.987'], ['2', '67.435', '-104.112']]

>>> [[float(i) for i in sub_list] for sub_list in my_list]
[[0.0, 23.345, -122.456], [1.0, 12.546, -118.987], [2.0, 67.435, -104.112]]

读取文件时,以列表方式使用map

import csv

with open("csvfile.csv", "rb") as f:
    lines = [map(float, line) for line in csv.reader(f)]

使您无需两次创建列表(阅读,转换)

您可以将map()列表推导一起使用

[map(float, sub_list) for sub_list in my_list]

输出:

>>> [map(float, sub_list) for sub_list in my_list]
[[0.0, 23.345, -122.456], [1.0, 12.546, -118.987], [2.0, 67.435, -104.112]]

更改:

lines = list(csv.reader(f))

变成:

lines = [[float(x) for x in line] for line in csv.reader(f)]

即:

import csv
    with open("csvfile.csv", "rb") as f:
        lines =  [[float(x) for x in line] for line in csv.reader(f)]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM