python – 在列表推导中使用就地列表方法的替代方法?

我知道就地列表方法返回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循环,它更容易理解.

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...