所以我有一个以下形式的数组:
[(1, u'first_type', u'data_gid_1'), (2, u'first_type', u'data_gid_2'), (3, u'first_type', u'data_gid_3'), (4, u'first_type', u'data_gid_4')]
现在我想将每个内部列表的第一个和最后一个元素提取到单独的列表中.所以,如果我这样做:
>>> ids = [dat[0] for dat in all_data] >>> gds = [dat[2] for dat in all_data]
这有点像我期望的那样.但是我试图将这两个合并为一个调用,例如:
(ids, gds) = [(dat[0], dat[2]) for dat in all_data]
然而,这失败了:
ValueError: too many values to unpack
所以任何人都可以解释为什么会发生这种情况,如果我想做的话甚至是可能的.
此致,波格丹
它不起作用,因为长度[(dat[0], dat[2]) for dat in all_data]
与长度all_data
相同,长度与元组的长度不同(ids, gds)
.
试试这个:
(ids, gds) = zip(*[(dat[0], dat[2]) for dat in all_data])
甚至更短:
(ids, gds) = zip(*all_data)[::2]
正如指出的另一种回答,ids
而gds
现在将元组,所以如果你需要列出,这样做:
(ids, gds) = map(list, zip(*all_data)[::2])
这zip(*something)
是python中经常出现的习语.如果将列表列表看作矩阵,即
l = [[1, 2, 3], [4, 5, 6]]
然后zip(*l)
转置该矩阵:
zip(*l) == [(1, 4), (2, 5), (3, 6)]
*
像这样的工作:some_func(*some_list)
解包, some_list
以便使用some_list
as参数元素调用该函数.所以zip(*l)
是一样的zip([1, 2, 3], [4, 5, 6])
.这是 python教程的相关部分.
zip
像拉链一样,因此名称,所以它返回一个包含这些元素的列表:给定参数的所有第一个元素的元组,后跟所有第二个元素的元组,等等.