Python 中是否有一种简单的方法(使用 itertools 或其他方式)将嵌套可迭代 f
转换为其相应的列表或元组?我想保存 f
以便可以对其进行多次迭代,这意味着如果 f
的某些嵌套元素是生成器,我就会遇到麻烦。
我将给出一个输入/输出示例。
>>> g = iter(range(2))
>>> my_input = [1, [2, 3], ((4), 5), [6, g]]
>>> magical_function(my_input)
[1, [2, 3], [[4], 5], [6, [0, 1]]]
如果输出也包含元组就好了。问题在于,迭代 g
会“消耗”它,因此无法再次使用它。
最佳答案
这似乎最好通过检查每个元素是否可迭代来完成,如果它是可迭代的,则对其调用递归函数。就像一个快速的草稿一样,我会尝试这样的事情:
import collections
g = iter(range(2))
my_input = [1, [2, 3], ((4), 5), [6, g]]
def unfold(iterable):
ret = []
for element in iterable:
if isinstance(element, collections.Iterable):
ret.append(unfold(element))
else:
ret.append(element)
return ret
n = unfold(my_input)
print(n)
print(n)
返回
$ python3 so.py
[1, [2, 3], [4, 5], [6, [0, 1]]]
[1, [2, 3], [4, 5], [6, [0, 1]]]
这不是最漂亮的方式,您可以找到改进它的方法(它将所有内容放在列表中而不是保留元组),但这是我会使用的总体想法。
关于python - 将嵌套的可迭代对象转换为列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36726129/