15

次のようなネストされたリストがあります。

    my_list = [[1320120000000, 48596281], [1320206400000, 48596281], [1320292800000, 50447908]]

これを次のように分割したいと思います。

    my_list1 = [48596281, 48596281, 50447908] 
    my_list2 = [1320120000000, 1320206400000, 1320292800000]    

これがかなり単純であることはわかっていますが、機能させることができませんでした。どんな助けでも大歓迎です。

4

3 に答える 3

28

これが組み込み関数zipの目的です。

my_list2, my_list1 = zip(*my_list)

タプルの代わりにリストが必要な場合は、次のことができます

my_list2, my_list1 = map(list, zip(*my_list))
于 2012-10-30T23:54:15.647 に答える
8

リスト内包表記を使用できます。

my_list1 = [i[1] for i in my_list]
my_list2 = [i[0] for i in my_list]
于 2012-10-30T23:54:17.443 に答える
4

使用 list comprehension:

In [6]: lis1,lis2=[x[0] for x in my_list],[x[1] for x in my_list]
In [7]: lis1
Out[7]: [1320120000000L, 1320206400000L, 1320292800000L]

In [8]: lis2
Out[8]: [48596281, 48596281, 50447908]

または使用operator.itemgetter()

In [19]: lis1,lis2=map(itemgetter(0),my_list) , map(itemgetter(1),my_list)

In [20]: lis1
Out[20]: [1320120000000L, 1320206400000L, 1320292800000L]

In [21]: lis2
Out[21]: [48596281, 48596281, 50447908]

timeit比較:

In [42]: %timeit lis1,lis2=[x[0] for x in my_list],[x[1] for x in my_list]  #winner if lists are required
100000 loops, best of 3: 1.72 us per loop

In [43]: %timeit my_list2, my_list1 = zip(*my_list) # winner if you want tuples
1000000 loops, best of 3: 1.62 us per loop

In [44]: %timeit my_list2, my_list1 = map(list, zip(*my_list))
100000 loops, best of 3: 4.58 us per loop

In [45]: %timeit lis1,lis2=map(itemgetter(0),my_list),map(itemgetter(1),my_list)
100000 loops, best of 3: 4.4 us per loop
于 2012-10-30T23:54:30.893 に答える