是否可以在维护“结构”的同时“清除”python中的(嵌套)列表。我的意思是如果输入是
[1,3,4,[5,2,[4,3],3],6,[7,8],9]
输出将是
[0,0,0,[0,0,[0,0],0],0,[0,0],0]
其中维护列表的实际结构,并重置值。
上下文:实际上并不存在,我只是想到了这个问题,我想知道是否可以这样做。。
发布于 2014-04-02 07:21:56
下面是一个使用鸭子类型原则的实现:
In [5]: def clear(seq):
...: for i, item in enumerate(seq):
...: try:
...: clear(item)
...: except TypeError:
...: try:
...: seq[i] = 0
...: except IndexError, KeyError:
...: pass
...:
In [6]: s = [1,3,4,[5,2,[4,3],3],6,[7,8],9]
In [9]: clear(s)
In [10]: s
Out[10]: [0, 0, 0, [0, 0, [0, 0], 0], 0, [0, 0], 0]
这样做的好处是,您不局限于int
或list
的结构/值,该函数将“零”出任何支持索引的可变结构。
发布于 2014-04-02 07:10:46
>>> l = [1,3,4,[5,2,[4,3],3],6,[7,8],9]
>>> def reset(lst):
... return [reset(e) if isinstance(e, list) else 0 for e in lst]
...
>>> l = reset(l)
>>> l
[0, 0, 0, [0, 0, [0, 0], 0], 0, [0, 0], 0]
发布于 2014-04-02 02:31:30
我用递归来处理这个问题,尽管它有点原始。
注意: ints和列表只能是任意的随机嵌套。为所有人工作
def set_zero(lst):
for i,element in enumerate(lst):
if type(element) != list: lst[i]=0
else: set_zero(element)
>>> a = [1,3,4,[5,2,[4,3],3],6,[7,8],9]
>>> set_zero(a)
>>> print(a)
[0,0,0,[0,0,[0,0],0],0,[0,0],0]
顺便问个好问题!
https://stackoverflow.com/questions/22808251
复制