def partition(n, iterable):
p = izip_longest(*([iter(iterable)] * n))
r = []
for x in p:
print(x) #I added this
s = set(x)
s.discard(None)
r.append(list(s))
return r
这实际上是在SO上的一个职位发布,并且是一个新手我觉得它很有趣.所以你得到如下输出:
partition(5, L)
(1, 2, 3, 4, None)
Out[86]: [[1, 2, 3, 4]]
对我来说这已经令人困惑,因为我认为izip_longest(*([iter(iterable)] * n))会在n个相同迭代器的列表上运行izip_longest函数,所以我原先预计输出为(1,1,1) ,1,1)然后输出(2,2,2,2,2)等.
这个问题的简短版本就是这一行:
p = izip_longest(*([iter(iterable)] * n))
解析它我会想[iter(iterable)] * n创建一个长度为n的相同iterables的列表,它们都指向同一个东西 – 这就是它在命令行上的作用,但这似乎不是它的作用这里基于上面印刷的输出.
另外我认为开头的*最长(* …是因为列表长度未知但我认为完全没有意义.函数调用中的第一个*符号是什么?看起来它只是表明一个未知长度的参数列表……
所以在一天结束的时候,我完全迷失了.有人可以告诉我这个语法吗?
非常感谢任何输入!
感谢所有有用的答案,每个人.我不确定我是否正在寻找答案或问题,但在我看来,这个列表理解将对列表和元组做同样的事情(我意识到迭代器也适用于字典,自定义类,其他东西.. .)
[L[i*n:(i+1)*n] for i in range(int(ceil(len(L)/float(n)))) ]