3 回答
TA贡献1856条经验 获得超11个赞
您可以首先使用列表理解从第一个列表中提取键和值:
keys = [row[1] for row in l] values = [[row[0], row[2],row[3]] for row in l]
然后使用相同的技术创建字典:
{k:v for k,v in zip(keys,values)}
(该zip
函数允许同时迭代 2 个列表键和值)
对于问题 2:不幸的是,您不能在字典中多次使用相同的键,您可能必须使用它len(keys) == len(set(keys))
来测试您的键列表是否有重复项(该set
函数从列表中提取所有唯一值)。
TA贡献1798条经验 获得超3个赞
尝试这个:
my_dict = {}
for sub_list in vals:
val_key = sub_list[1]
if val_key in my_dict:
my_dict[val_key].extend([sub_list[0]] + sub_list[2:])
else:
my_dict[val_key] = [sub_list[0]] + sub_list[2:]
创建一个空字典来放置您的值。
浏览数据中的所有条目。
输入该条目的键 (
sub_list[1]
),我们将使用它来索引我们的字典。如果该键已经存在,则使用该项目的非值扩展存储在该列表中的值
[1]
(例如['a', 'b', 'c']
变为['a', 'b', 'c', 'd', 'e']
)。如果该键不存在,只需在字典中使用非
[1]
值创建一个新键。
TA贡献1906条经验 获得超10个赞
raw = [
# <date> <key> <val1> <val2>
['2020/10/07', 'AAA123', '19.24', '22.00'],
['2020/11/17', 'BBB123', '23.59', '00.00'],
['2020/14/67', 'AAA123', '08.00', '16.00'],
]
(稍微编辑您的示例以具有重复的密钥)
听起来你希望你的输出是这样的:
{key: [info, ...], ...}
我们可以这样做:
from collections import defaultdict, namedtuple
Data = namedtuple('Data', ('date', 'val1', 'val2'))
res = defaultdict(list)
for date, key, val1, val2 in raw:
data = Data(date, val1, val2)
res[key].append(data)
res = dict(res) # Strip defaultdict behavior
然后我们可以看到
import pprint
pprint.pprint(res)
给我们一个与期望类似的结果:
{'AAA123': [Data(date='2020/10/07', val1='19.24', val2='22.00'),
Data(date='2020/14/67', val1='08.00', val2='16.00')],
'BBB123': [Data(date='2020/11/17', val1='23.59', val2='00.00')]}
添加回答
举报