亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

python - 如何利用元組中某個數(shù)據(jù)或字典中某組key,對一個序列的數(shù)據(jù)進(jìn)行排序?

瀏覽:103日期:2022-06-29 15:57:33

問題描述

假設(shè)通過對海量的原始數(shù)據(jù)后分析得到這樣的數(shù)據(jù):

[(id,node,val)(id,node,val)...]就是依次為 用戶id,所在服務(wù)器,數(shù)值 這樣的元組,然后要根據(jù)服務(wù)器分開,再依靠val大小進(jìn)行排序,然后寫入excel中。或者產(chǎn)生[{'id':xxx,'node':xxx,'val':xxx},{'id':xxx,'node':xxx,'val':xxx}...]如果是只有一組kv,可以通過sorted的方式進(jìn)行排序,但是現(xiàn)在node的名稱是未知的,這些服務(wù)器名每天都可以能會發(fā)生變化。當(dāng)我獲取到這樣的數(shù)據(jù)后,如何根據(jù)服務(wù)器名稱分開,再排序數(shù)據(jù)呢?這里主要卡在,node本身的名稱并不是固定的,比如你先創(chuàng)建n個列表,把相同節(jié)點(diǎn)的數(shù)據(jù)放進(jìn)去,但你不知道要創(chuàng)建多少個列表。而且之后在將處理后的數(shù)據(jù)寫入excel時,勢必要用到循環(huán)。這樣循環(huán)套循環(huán),而且無論是數(shù)據(jù)分類后,還是排布后的新數(shù)據(jù)組名稱都不是確定的。即便使用exec命令也無法滿足需要啊

問題解答

回答1:

from collections import defaultdictd = defaultdict(list)data = [(id,node,val),(id,node,val)...]# 按node進(jìn)行分組for x in data: d[x[1]].append(x) # 將分組數(shù)據(jù)依次寫入excelfor _, v in d.iteritems(): # 排序 tmp = sorted(v, key=lambda x: x['val'], reverse=True/False) # 寫入excel write_to_excel(tmp)

另外其實(shí)可以將數(shù)據(jù)按id, node, val 全部寫入csv文件通過linux的awk, uniq, sort 等命令工具寫一個shell腳本, 也是很快的

還有關(guān)于你的海量數(shù)據(jù)究竟有多大, 在哪個數(shù)量級,沒有明確, 如果數(shù)據(jù)量真的很大, 用上面的python代碼內(nèi)存不夠用也是可能的, 這個需要你自己估算下

回答2:

如果我正確理解了你的需求的話,可以用字典,字典的鍵是node的名稱,字典的值是由項(xiàng)組成的列表:

data = [{'id':xxx,'node':xxx,'val':xxx},{'id':xxx,'node':xxx,'val':xxx}...]result = {}for data_item in data: node_name = data_item['node'] if node_name in result.keys():result[node_name].append(data_item) else:result[node_name] = [data_item]

之后再根據(jù)鍵(服務(wù)器名稱)取出字典中的每一項(xiàng)的值(就是數(shù)據(jù)列表),對其sort加lambda根據(jù)每一項(xiàng)中的某個值進(jìn)行排序。

標(biāo)簽: Python 編程
主站蜘蛛池模板: 亚洲在线观看免费视频 | 免费的三级网站 | 91精品91| 久久综合亚洲一区二区三区 | 18视频免费网站 | 国产男女乱淫真视频全程播放 | 欧美一级毛片一 | 日本道色 | 真实一级一级一片免费视频 | 美女扒开腿让男人桶爽免费动态图 | 国产一区二区三区高清视频 | 韩国免费毛片在线看 | 黄色免费看片网站 | 久久久免费视频播放 | 成人福利网站在线看视频 | 久久免费毛片 | 一本综合久久国产二区 | 成人二区 | 香蕉三级 | 韩国一级永久免费观看网址 | 日韩一区二区在线播放 | 欧美在线做爰高清视频 | 亚洲精品一区二区在线播放 | 欧美国产在线看 | 国产伦码精品一区二区 | 久久狠狠一本精品综合网 | 久久福利青草精品资源 | 精品一区二区三区视频在线观看 | 国产精品久久国产三级国不卡顿 | 国产成人精品视频一区 | 欧美成a人免费观看久久 | 91香蕉网 | 一级黄色毛片免费看 | 久久精品国产99国产精品免费看 | 国产日本在线 | 一本色道久久综合网 | 国产伦精品一区二区三区无广告 | 全部毛片| 久久九九爱 | 亚洲天堂精品在线观看 | 一级床上爽高清播放 |