我正在寻找一种更加pythonic的方式来循环开始索引的列表然后返回子列表中包含的值,例如:
values = [[1,2], [2], [1,3,4]]
n=1
for i, item in enumerate(values[n:]):
i += n
if i < len(values):
for sub_value in values[i]:
print("index: "+str(i)+ " list: "+str(item)+ " sub value: "+str(sub_value))
代码按预期工作,但非常难看,有任何简化它的想法吗?
答案 0 :(得分:1)
我不确定我是否完全理解你想要实现的目标。如果你想打印索引1中的项目的平面列表,你可以这样做:
[item for sublist in values[1:] for item in sublist]
产生:
[2, 1, 3, 4]
答案 1 :(得分:0)
我要在这里进行一下,并猜测你正在尝试创建一个简单的python函数,它循环遍历列表并打印出子列表中的每个元素。这是最简单的方法:
def get_sublists(start=0):
values = [[1,2], [2], [1,3,4]]
index = start
item = 0
for value in values[index:]:
for sub_value in value:
print("Item: %s // Index: %s // List: %s // Sub Value: %s" % (item, index, values[index], sub_value))
item += 1
index += 1
get_sublists(1)
这将打印出以下内容:
Item: 0 // Index: 1 // List: [2] // Sub Value: 2
Item: 1 // Index: 2 // List: [1, 3, 4] // Sub Value: 1
Item: 2 // Index: 2 // List: [1, 3, 4] // Sub Value: 3
Item: 3 // Index: 2 // List: [1, 3, 4] // Sub Value: 4
我对这个问题并不是100%肯定,因为它有点暧昧,所以如果你有任何进一步的修改,请告诉我。