将元组转换为字典列表

时间:2020-10-17 07:39:48

标签: python json

我在将两个元组转换成字典列表时遇到麻烦。结构如下:

train_detail = (Counter({2: 50, 0: 62, 1: 38}),
 {2: 0.3333333333333333, 0: 0.41333333333333333, 1: 0.25333333333333335})

test_detail = (Counter({2: 6, 0: 49, 1: 4}),
 {2: 0.1016949152542373, 0: 0.8305084745762712, 1: 0.06779661016949153})

现在我想将这两部分变成如下结构:

 [
        {
            "label": "0",
            "trainPercent": 0.41333333333333333,
            "trainNumber": 62,
            "testPercent": 0.8305084745762712,
            "testNumber": 49,
        },
        {
            "label": "1",
            "trainPercent": 0.25333333333333335,
            "trainNumber": 38,
            "testPercent": 0.06779661016949153,
            "testNumber": 4,
        },
        {
            "label": "2",
            "trainPercent": 0.3333333333333333,
            "trainNumber": 50,
            "testPercent": 0.1016949152542373,
            "testNumber": 6,
        },      
    ]

什么是最小化循环的有效方法?谢谢。注意 Counter 是dict的子类,因此继承了常规dict的每个方法。

3 个答案:

答案 0 :(得分:2)

from pprint import pprint
from collections import Counter


train_detail = (Counter({2: 50, 0: 62, 1: 38}),
 {2: 0.3333333333333333, 0: 0.41333333333333333, 1: 0.25333333333333335})

test_detail = (Counter({2: 6, 0: 49, 1: 4}),
 {2: 0.1016949152542373, 0: 0.8305084745762712, 1: 0.06779661016949153})

out = []
for t in train_detail[0]:
    out.append({
        'label': str(t),
        'trainNumber': train_detail[0][t],
        'trainPercent': train_detail[1][t],
        'testPercent': test_detail[1][t],
        'testNumber': test_detail[0][t]
    })

# pretty print to screen:
pprint(out)

打印:

[{'label': '2',
  'testNumber': 6,
  'testPercent': 0.1016949152542373,
  'trainNumber': 50,
  'trainPercent': 0.3333333333333333},
 {'label': '0',
  'testNumber': 49,
  'testPercent': 0.8305084745762712,
  'trainNumber': 62,
  'trainPercent': 0.41333333333333333},
 {'label': '1',
  'testNumber': 4,
  'testPercent': 0.06779661016949153,
  'trainNumber': 38,
  'trainPercent': 0.25333333333333335}]

答案 1 :(得分:0)

使用lambda函数。lambda用于解压缩元组。

答案 2 :(得分:0)

感谢@Andrej Kesely和@BjörnMarschollek

结合他们的答案:

labels_detail_list = [{'label': str(i), 
                       'trainNumber': train_detail[0][i], 
                       'trainPercent': train_detail[1][i],
                       'testNumber': test_detail[0][i],
                       'testPercent': test_detail[1][i]
                      } for i in train_detail[0]]

sorted(labels_detail_list, key=lambda x: int(x['label']))

应该是更简洁的版本。