我知道就地列表方法返回None而不是变异列表.据我所知,这使得不可能将这些方法用作列表理解的内部逻辑的一部分.
什么是创建列表理解的最pythonic方法,其成员来自变异其他列表?换句话说:这个(无功能)线的最佳替代方案是什么:
new_list = [old_list.insert(0,"X") for old_list in list_of_old_lists]
这导致Nones列表,因为list.insert()返回None.
是否根本不可能在优雅的单行代码中执行此操作而无需大量切片和连接?
上面的例子是为了说明我的问题是微不足道的,但实际上我想在更复杂的情况下这样做,而不是多个嵌套的’for’循环.
这是我正在尝试做的简化示例:
word = 'abcdefg' variations_list = [] characters_to_insert = ['X','Y','Z'] for character in characters_to_insert: for position in range(len(word) + 1): w = list(word) w.insert(position,character) this_variation = ''.join(w) variations_list.append(this_variation) for v in variations_list: print(v)
使用嵌套的’for’循环可以正常工作,这样(我的实际应用程序比此示例复杂/冗长).
但我不能使用列表推导做同样的事情,因为’insert’方法返回None:
variations_list_comprehension = [list(word).insert(position,character) for position in range(len(word) +1) for character in ['X','Z']] for v in variations_list_comprehension: print(v)
结果列出None值,因为就地突变返回“None”.
解决方法
如果您不关心改变其他列表的结果,那么您不需要使用临时列表:
variations_list = [word[:i] + char + word[i:] for char in characters_to_insert for i in range(len(word) + 1)] ['Xabcdefg','aXbcdefg','abXcdefg','abcXdefg','abcdXefg','abcdeXfg','abcdefXg','abcdefgX','Yabcdefg','aYbcdefg','abYcdefg','abcYdefg','abcdYefg','abcdeYfg','abcdefYg','abcdefgY','Zabcdefg','aZbcdefg','abZcdefg','abcZdefg','abcdzefg','abcdeZfg','abcdefZg','abcdefgZ']
我仍然会说这至多是一种边缘理解:作为一个for循环,它更容易理解.