来自2D数组的多键字典

时间:2019-04-08 22:10:24

标签: python csv dictionary multikey

尝试使用列表中的值创建多键字典,其中字典的键为第一列和第一行值(空单元格除外)。

以下代码未返回预期结果。我也尝试过使用地图功能和列表理解功能。

# list data
list_data = [[, , 'VARIANT1', 'VARIANT2'],
         ['power', 'kW', '12', '20'],
         ['range', 'm', '200', '400'],
         ['colour', , 'blue', 'yellow']]

# my code
import collections
dict_data = collections.defaultdict()
for row in range(1: len(list_data)):
    for column in range(2: len(list_data[0])):
        dict_data[(list_data[row][0], list_data[0][column])
              ] = list_data[row][column]

# desired output
dict_data = {('power', 'VARIANT1'): '12',
         ('range', 'VARIANT1'): '200',
         ('colour', 'VARIANT1'): 'blue',
         ('power', 'VARIANT2'): '20',
         ('range', 'VARIANT2'): '400',
         ('colour', 'VARIANT2'): 'yellow', }

1 个答案:

答案 0 :(得分:0)

您可以通过字典理解来做到这一点:

<a href="" ng-click="editValueForItem($event)">
    {{ item.value }}
</a>

输出:

editValueForItem = function($event) {
    let $target = angular.element($event.target);
    let nextInput = $target.parent().parent().find('input')[0];

    if (nextInput.length) {
        nextInput.focus();
    }
}

或排序为示例输出:

list_data = [['', '', 'VARIANT1', 'VARIANT2'],
         ['power', 'kW', '12', '20'],
         ['range', 'm', '200', '400'],
         ['colour','' , 'blue', 'yellow']]


keys = {(x[0], y): x[i]  for x in list_data[1:] for i, y in enumerate(list_data[0]) if i >= 2}

keys_sorted = {k: v for k, v in sorted(keys.items(), key=lambda x: x[0][1])}