“我的数据”是具有r行的列表的列表,这些行的长度各不相同,其中包含数据字符串-其中一些是浮点数,但已作为字符串读取。
我想先遍历所有行,然后遍历所有 elements ,然后在上述 elements 上应用try / except函数,以查找字符串的第一个实例在可以转换为浮点数的行中。
当我明确告诉第二个循环应该对哪一行进行操作时,我的代码输出预期,但是,当我尝试遍历所有行时,它仅输出第一行的预期输出,而没有输出接下来的行。
预期输出列表 float_index (长度= len(data))将是一个列表,其中包含所有行的第一个可转换元素的索引。
以下是带有显式行定义输出[2]的代码,因为对于第二行,它是可转换为float的第二个元素:
data = [['Mittl.', 'Halleninnenpegel,', 'Volllast', 'Li', '124', '132', '132', '132', '139', '138', '141', '139', '131', '146'],
['Abgaskamin', 'LW', '130', '129', '121', '104', '100', '96', '94', '89', '86', '108']]
row= 1
floats = []
float_index = []
for i in data[row]:
try:
floats.append(str(int(float(i))))
float_index = [data[row].index(floats[0])]
except:
pass
print(float_index)
这是循环数据中所有行的代码,但只输出第一行的期望值float_index = [4],而期望的是float_index = [4,2]:
data = [['Mittl.', 'Halleninnenpegel,', 'Volllast', 'Li', '124', '132', '132', '132', '139', '138', '141', '139', '131', '146'],
['Abgaskamin', 'LW', '130', '129', '121', '104', '100', '96', '94', '89', '86', '108']]
floats = []
float_index = []
for r in range(len(data)):
for i in data[r]:
try:
floats.append(str(int(float(i))))
float_index = [data[r].index(floats[0])]
except:
pass
print(float_index)
floats 列表可能是问题-它只是将所有可转换元素收集到一个只有一行的长列表中-我需要 floats 列表具有相同的方式作为 data ,它将所有可转换元素放入新行中,因此通过 floats [0] 我找到了所有行的第一个元素,但由于某种原因无法获取我的努力实现这一目标。
感谢您的帮助,谢谢!
答案 0 :(得分:-2)
无需遍历每个元素,只需在找到第一个元素后就退出循环:
data = [['Mittl.', 'Halleninnenpegel,', 'Volllast', 'Li', '124', '132', '132', '132', '139', '138', '141', '139', '131', '146'],
['Abgaskamin', 'LW', '130', '129', '121', '104', '100', '96', '94', '89', '86', '108']]
floats = []
float_index = []
for lest in data:
float_temp = None
float_ind_temp = None
for el in lest:
try:
float_temp = str(int(float(el)))
floats.append(float_temp)
float_index_temp = lest.index(float_temp)
break
except:
pass
float_index.append(float_index_temp)
print(float_index)