不同的方法:当我进行替换时,我更喜欢从字典的角度进行思考。所以我会做类似的事情
>>> orig = [ 'a', 'b', 'c', 'd' ]>>> rep = {'c': ['x', 'y', 'z']}>>> [i for c in orig for i in rep.get(c, [c])]['a', 'b', 'x', 'y', 'z', 'd']
最后一行是标准拼合成语。
这种方法的一个优点(劣势?)是它将处理的多次出现
'c'。
[更新:]
或者,如果您愿意:
>>> from itertools import chain>>> list(chain.from_iterable(rep.get(c, [c]) for c in orig))['a', 'b', 'x', 'y', 'z', 'd']
关于修改后的测试用例:
>>> orig = [ 'a', 'b', 'c', 'd', 'c' ]>>> rep = {'c': ['x', 'y', 'z']}>>> list(chain.from_iterable(rep.get(c, [c]) for c in orig))['a', 'b', 'x', 'y', 'z', 'd', 'x', 'y', 'z']
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)