所以我有一个以下形式的数组:
[(1,u'first_type',u'data_gid_1'),(2,u'data_gid_2'),(3,u'data_gid_3'),(4,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:要解压缩的值太多
所以任何人都可以解释为什么会发生这种情况,如果我想做的话甚至是可能的.
问候,
波格丹
最佳答案
它不起作用,因为all_data中dat的[(dat [0],dat [2])的长度与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),5),6)]
*的工作方式如下:some_func(* some_list)解包some_list,以便使用some_list的元素作为参数调用该函数.因此zip(* l)与zip([1,6])相同. Here’s python教程的相关部分.
zip
的作用类似于zipper,因此它的名称,因此它返回一个包含这些元素的列表:给定参数的所有第一个元素的元组,后跟所有第二个元素的元组,等等.