Python从索引开始循环遍历列表

时间:2015-03-21 03:17:29

标签: python python-3.x logic

我正在寻找一种更加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))

代码按预期工作,但非常难看,有任何简化它的想法吗?

2 个答案:

答案 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%肯定,因为它有点暧昧,所以如果你有任何进一步的修改,请告诉我。