第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

如何對(duì)列表中的元素進(jìn)行分組?

如何對(duì)列表中的元素進(jìn)行分組?

弒天下 2023-10-18 16:20:53
我有一個(gè)清單。每個(gè)列表包含三個(gè)元素,將它們稱(chēng)為[number, letter, time]。它看起來(lái)像這樣:my_list = [[0, 'a', '0:00'],           [1, 'a', '1:00'],           [2, 'b', '2:00'],           [3, 'c', '3:00'],           [4, 'b', '4:00'],           [5, 'a', '5:00'],           [6, 'd', '6:00'],           [7, 'c', '7:00'],           [8, 'b', '8:00'],           [9, 'e', '9:00']]我想格式化此列表element[1],使得letter每個(gè)嵌套列表的 成為一個(gè)新的嵌套列表,其中和的element[0]出現(xiàn)為和。numbertimeelement[1]element[2]我想要的輸出應(yīng)該是這樣的my list = [['a', [0, 1, 5], ['0:00', '1:00', '5:00']],           ['b', [2, 4, 8], ['2:00', '4:00', '8:00']],           ['c', [3, 7], ['3:00', '7:00']],           ['d', [6], ['6:00']],           ['e', [9], ['9:00']]]到目前為止我已經(jīng)習(xí)慣了collections.Counter()獲取頻率letter>>> letter_count = Counter([element[1] for element in my_list])>>> letter_countCounter({'a': 3, 'b': 3, 'c': 2, 'd': 1, 'e': 1})我相信我可以使用列表理解來(lái)完成其余的工作,使用letter_count.keys()and 條件,但我被困住了。有什么建議么?另外,歡迎提出更好、更具描述性的標(biāo)題(為了子孫后代)的建議。
查看完整描述

3 回答

?
慕田峪9158850

TA貢獻(xiàn)1794條經(jīng)驗(yàn) 獲得超8個(gè)贊

out = {}

for a, b, c in my_list:

    out.setdefault(b, []).append((a, c))


out = [[k, [i for i, _ in v], [i for _, i in v]]  for k, v in out.items()]


print(out)

印刷:


[['a', [0, 1, 5], ['0:00', '1:00', '5:00']], 

 ['b', [2, 4, 8], ['2:00', '4:00', '8:00']], 

 ['c', [3, 7], ['3:00', '7:00']], 

 ['d', [6], ['6:00']], 

 ['e', [9], ['9:00']]]


查看完整回答
反對(duì) 回復(fù) 2023-10-18
?
慕神8447489

TA貢獻(xiàn)1780條經(jīng)驗(yàn) 獲得超1個(gè)贊

另一種方法是使用itertools.groupby


import itertools


new_list = []

my_list = sorted(my_list, key=lambda row: row[1])

for name, groups in itertools.groupby(my_list, key=lambda row: row[1]):

    groups = list(zip(*groups))

    

    grouped_item = [name, groups[0], groups[2]]

    new_list.append(grouped_item)

    

print(new_list)

[['a', (0, 1, 5), ('0:00', '1:00', '5:00')],

 ['b', (2, 4, 8), ('2:00', '4:00', '8:00')],

 ['c', (3, 7), ('3:00', '7:00')],

 ['d', (6,), ('6:00',)],

 ['e', (9,), ('9:00',)]]


查看完整回答
反對(duì) 回復(fù) 2023-10-18
?
一只甜甜圈

TA貢獻(xiàn)1836條經(jīng)驗(yàn) 獲得超5個(gè)贊

這是一種快速而骯臟的方法(與當(dāng)前其他答案相同的效率,但更多的代碼)


my_list = [[0, 'a', '0:00'],

           [1, 'a', '1:00'],

           [2, 'b', '2:00'],

           [3, 'c', '3:00'],

           [4, 'b', '4:00'],

           [5, 'a', '5:00'],

           [6, 'd', '6:00'],

           [7, 'c', '7:00'],

           [8, 'b', '8:00'],

           [9, 'e', '9:00']]


tmp_dict = {}


for first, second, third in my_list:

    if second not in tmp_dict:

        tmp_dict[second] = [[],[]]


    tmp_dict[second][0].append(first)

    tmp_dict[second][1].append(third)


new_list = []


for key, val in tmp_dict.items():

    new_list.append([key] + val)


print(new_list)


查看完整回答
反對(duì) 回復(fù) 2023-10-18
  • 3 回答
  • 0 關(guān)注
  • 177 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)