Existe-t-il un moyen d'utiliser Python pour générer cette chaîne de données dans le format souhaité ?
漂亮男人
漂亮男人 2017-06-12 09:21:18
0
3
679
[('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, '张三')]

Je souhaite afficher la chaîne de données ci-dessus au format

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

Avec ce format, existe-t-il un autre moyen ? J'y réfléchis depuis longtemps et je n'arrive pas à trouver un moyen efficace de le faire.

漂亮男人
漂亮男人

répondre à tous(3)
伊谢尔伦
# python2
# coding: utf8
a = [('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

为情所困
from collections import defaultdict

d = 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()]
女神的闺蜜爱上我

Dans ce cas, le module pandas devrait être utilisé pour le rendre plus durable :

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 pd
df = 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變成list
print ( [{'data':list(d.loc[x].values.tolist()) , 'name': x} for x in set(d.index) ] )   

La dernière ligne est le résultat que vous souhaitez. Fondamentalement, il utilise le résultat de l'index de l'avant-dernière ligne comme base de dérivation de liste pour produire le dictionnaire souhaité, qui contient le nom et les données, et les données contiennent les données répertoriées dans la liste

[{'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': '张三'}]
  
  

Si vous avez besoin de plus de traitement de données, je vous recommande vraiment d'apprendre le module pandas.

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal