为列表推导切片列表但保留切片值

时间:2015-01-20 14:01:11

标签: python python-2.7 list-comprehension slice

我想根据值是否为None,将布局值替换为items[1]items[2]items[3]。这有效,但会从输出中删除items[0]items[4]items[5]。我可以插入/追加值,但我认为必须有一种方法可以在一行中完成。

my_list = [[10,30,None,20,30,40],[10,20,None,10,30,40]]
booleans = [[1 if item is None else 0 for item in each_list[1:-2]] for each_list in my_list]
print booleans

预期产出:

[[10, 0, 1, 0, 30, 40], [10, 0, 1, 0, 30, 40]]

3 个答案:

答案 0 :(得分:5)

你很接近,你可以在迭代内部列表时使用enumerate并测试索引是否在应该修改的集合中。这允许您通过简单地修改tests集合来轻松修改应该测试哪些索引,并且不需要某种形式的切片,这很容易修改。

my_list = [[10,30,None,20,30,40],[10,20,None,10,30,40]]
tests = {1, 2, 3}

new_list = [[v if i not in tests else 1 if v is None else 0 for i, v in enumerate(x)] 
            for x in my_list]

print(new_list)
# [[10, 0, 1, 0, 30, 40], [10, 0, 1, 0, 30, 40]]

就个人而言,我不会在这种情况下使用列表理解,因为它是丑陋的。下面的代码完全相同,更具可读性:

my_list = [[10,30,None,20,30,40],[10,20,None,10,30,40]]
tests = {1, 2, 3}

for x in my_list:
    for i, v in enumerate(x):
        if i in tests:
            x[i] = 1 if v is None else 0

print(my_list)
# [[10, 0, 1, 0, 30, 40], [10, 0, 1, 0, 30, 40]]

答案 1 :(得分:2)

使用嵌套列表推导:

booleans= [[l[0]]+[1 if i is None else 0 for i in l[1:4]]+l[4:] for l in my_list]

答案 2 :(得分:1)

您需要将剩余的列表(您不想替换其元素)添加到已编辑的子列表中:

>>> booleans = [each_list[0:1]+[1 if item is None else 0 for item in each_list[1:-2]]+each_list[4:] for each_list in my_list]
>>> print booleans
[[10, 0, 1, 0, 30, 40], [10, 0, 1, 0, 30, 40]]