例如,这是我正在循环的列表的示例,['n', 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16、17、18、19、20、21、22、23、24、25、26、27、28、29、30、31、32、33、34、35、36、37、'n'、'n ','n','n','n','n','n','n','n','n','n','n','n','n', 'n','n','n','n','n','n','n','n','n','n','n','n','n '、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n'、82、83、84、85、86、87、88、'n '、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n'、'n','n','n','n','n','n','n','n','n','n','n','n','n' ,'n','n','n','n','n','n','n','n','n',''n','n','n', 178、179、180]
该列表是从先前调用的函数生成的(已插入 n 以隐藏不需要的值)。
我正在尝试将在 n 之间分隔的数字分组并将它们发送到一个列表,例如取数字 1-37-> 放入列表中,取数字 82-88-> 不同列表,178-180-> 发送到不同的列表。
棘手的部分是列表中并不总是包含相同的数据集,“组”可以是任意大小和位置。唯一的定义特征是它们由 n 分隔。
到目前为止我的尝试:
for i in range(0, len(lists)):
for index, item in enumerate(lines):
if item != 'n': #if item is not n send to list
lists[i].append(item)
elif lines[index+1] == 'n':#if the next item is an n
del lines[:index]
其中“列表”实际上是在此函数之外创建的列表列表,为了存储每个组,列表的数量由需要存储的组的数量决定。
'lines' 是我希望循环的值列表。
我的逻辑是,所有不是“n”的值都附加在第一个列表中,如果下一个值是 n,则删除之前的所有值并循环遍历新列表,将下一组值放入下一个列表。很快。
除了我得到:列表索引超出范围
我明白,但我希望有办法绕过它。我也尝试在 elif 处跳出循环,但是我无法继续我离开的循环。我最后的尝试是在第一次运行后设置的位置重新启动循环,如下所示:
place=0
for i in range(0, len(lists)):
for index, item in enumerate(lines[place:]):
if item != 'n': #if item is not n send to list
lists[i].append(item)
elif lines[index+1] == 'n':#if the next item is an n
place=[index]
break
切片索引必须是整数或 None 或具有索引方法
希望这很清楚,有人可以帮忙吗?