av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

這串?dāng)?shù)據(jù)有什么方法用python輸出我想要的格式?

瀏覽:111日期:2022-06-29 16:39:36

問題描述

[(’2016-09’, 20874.73, ’李四’), (’2016-10’, 64296.45, ’李四’), (’2016-11’, 58657.1, ’李四’), (’2016-12’, 51253.14, ’李四’), (’2017-01’, 57791.88, ’李四’), (’2017-01’, 46007.0, ’張三’), (’2017-02’, 67193.55, ’李四’), (’2017-02’, 38352.0, ’張三’), (’2017-03’, 83359.53, ’李四’), (’2017-03’, 49661.0, ’張三’), (’2017-04’, 39907.0, ’張三’)]

上面這串?dāng)?shù)據(jù)我想輸出格式為

[{’data’: [[’2013-04’, 52.9], [’2013-05-01’, 50.7]], ’name’: ’張三’},{’data’: [[’2013-04’, 27.7], [’2013-05-01’, 25.9]], ’name’: ’李四’}]

這樣的格式,有什么還得方法嗎?想了好久想不到有效的做法。

問題解答

回答1:

# python2# coding: utf8a = [(’2016-09’, 20874.73, ’李四’), (’2016-10’, 64296.45, ’李四’), (’2016-11’, 58657.1, ’李四’), (’2016-12’, 51253.14, ’李四’), (’2017-01’, 57791.88, ’李四’), (’2017-01’, 46007.0, ’張三’), (’2017-02’, 67193.55, ’李四’), (’2017-02’, 38352.0, ’張三’), (’2017-03’, 83359.53, ’李四’), (’2017-03’, 49661.0, ’張三’), (’2017-04’, 39907.0, ’張三’)]s = []for i in a: for dict_tmp in s:if dict_tmp.get(’name’, ’’) == i[2]: dict_tmp[’data’].append([i[0], i[1]]) break else:s.append( {’name’: i[2],’data’: [[i[0], i[1]]] })print s回答2:

from collections import defaultdictd = defaultdict(list)l_data = [(’2016-09’, 20874.73, ’李四’), (’2016-10’, 64296.45, ’李四’), (’2016-11’, 58657.1, ’李四’), (’2016-12’, 51253.14, ’李四’), (’2017-01’, 57791.88, ’李四’), (’2017-01’, 46007.0, ’張三’), (’2017-02’, 67193.55, ’李四’), (’2017-02’, 38352.0, ’張三’), (’2017-03’, 83359.53, ’李四’), (’2017-03’, 49661.0, ’張三’), (’2017-04’, 39907.0, ’張三’)]for x in l_data: d[x[2]].append([x[0], x[1]])result = [{’name’: k, ’data’: v} for k, v in d.iteritems()]回答3:

這種情況應(yīng)該使用pandas模塊比較永續(xù):

data_input = [(’2016-09’, 20874.73, ’李四’), (’2016-10’, 64296.45, ’李四’), (’2016-11’, 58657.1, ’李四’), (’2016-12’, 51253.14, ’李四’), (’2017-01’, 57791.88, ’李四’), (’2017-01’, 46007.0, ’張三’), (’2017-02’, 67193.55, ’李四’), (’2017-02’, 38352.0, ’張三’), (’2017-03’, 83359.53, ’李四’), (’2017-03’, 49661.0, ’張三’), (’2017-04’, 39907.0, ’張三’)]import pandas as pddf = pd.DataFrame(data_input)df.columns = [’month’,’value’,’name’]d = df.set_index([’name’])print ( set(d.index) ) # {’張三’, ’李四’}print ( list(d.loc[’張三’].values.tolist()) ) # data變成listprint ( [{’data’:list(d.loc[x].values.tolist()) , ’name’: x} for x in set(d.index) ] )

最後一行就是你要的結(jié)果。基本上就是用倒數(shù)第三行索引結(jié)果為列表推導(dǎo)基礎(chǔ),產(chǎn)出你要的字典,內(nèi)有name及data,而data有列表出的數(shù)據(jù)

[{’data’: [[’2016-09’, 20874.73], [’2016-10’, 64296.45], [’2016-11’, 58657.1], [’2016-12’, 51253.14], [’2017-01’, 57791.88], [’2017-02’, 67193.55], [’2017-03’, 83359.53]], ’name’: ’李四’}, {’data’: [[’2017-01’, 46007.0], [’2017-02’, 38352.0], [’2017-03’, 49661.0], [’2017-04’, 39907.0]], ’name’: ’張三’}]

如果有更多數(shù)據(jù)處理的需要,真的很推薦把pandas模塊學(xué)起來。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 美女精品一区 | www.一区二区三区.com | 久久久久高清 | 日本一区视频在线观看 | 日韩欧美电影在线 | 国产精品国产三级国产aⅴ入口 | 成人福利在线视频 | 久久国产电影 | 黄网站免费在线看 | 古装人性做爰av网站 | 羞羞视频在线观看 | 国产精品久久国产精品 | 国产福利视频网站 | 综合久久av | 国产高清毛片 | av日韩在线播放 | 91精品国产综合久久久动漫日韩 | 国产高清免费视频 | 日本男人天堂 | 国产成人在线视频 | 婷婷在线免费 | 国产免费又色又爽又黄在线观看 | 欧美一区二区在线观看视频 | 九一在线观看 | 99国内精品久久久久久久 | 国产精品一区二区三区在线 | 在线视频91 | 欧美日韩在线视频一区二区 | 欧美影院久久 | 日本a级大片 | 日韩中文字幕免费在线观看 | 黄色片大全在线观看 | 久久不卡视频 | 久久综合久久久 | 精品国模一区二区三区欧美 | 一区二区三区视频 | 国产一区二区三区久久久久久久久 | 亚洲精品视频在线看 | 成人一区二区三区视频 | 色婷婷婷婷色 | 亚洲精品一区二区另类图片 |