首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何合并具有相同元素的不同列表

如何合并具有相同元素的不同列表
EN

Stack Overflow用户
提问于 2019-08-14 09:21:57
回答 2查看 62关注 0票数 1

查询数据库返回的结果

代码语言:javascript
复制
["www.google.com","2019-1-2","102"],
["www.fb.com","2019-1-4","292"],
["www.amazon.com","2019-3-2","142"],
["www.google.com","2019-6-2","162"],
["www.fb.com","2019-8-2","52"],
["www.fb.com","2019-3-2","522"],
["www.google.com","2019-8-5","591"]

我想要的列表样式结果:

代码语言:javascript
复制
["www.google.com",["2019-1-2","102"],["2019-6-2","162"],["2019-8-5","591"]],
["www.fb.com",["2019-1-4","292"],["2019-8-2","52"],["2019-3-2","522"]],
["www.amazon.com",["2019-3-2","142"]]

或者一种字典风格。

代码语言:javascript
复制
{"www.google.com":[["2019-1-2","102"],["2019-6-2","162"],["2019-8-5","591"]]},
{"www.fb.com":[["2019-1-4","292"],["2019-8-2","52"],["2019-3-2","522"]]},
["www.amazon.com":["2019-3-2","142"]}

尝试比较列表的第一个元素

代码语言:javascript
复制
temp = arr[0]
for x in result:
    if x[0] == temp
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-08-14 09:29:36

您可以使用defaultdict和一些列表拼接来解决此问题

代码语言:javascript
复制
from collections import defaultdict

data = defaultdict(list)

db = [["www.google.com","2019-1-2","102"],
      ["www.fb.com","2019-1-4","292"],
      ["www.amazon.com","2019-3-2","142"],
      ["www.google.com","2019-6-2","162"],
      ["www.fb.com","2019-8-2","52"],
      ["www.fb.com","2019-3-2","522"],
      ["www.google.com","2019-8-5","591"]]

for d in db:
    data[d[0]].append(d[1:])

print(data)

将打印

代码语言:javascript
复制
defaultdict(list,
        {'www.amazon.com': [['2019-3-2', '142']],
         'www.fb.com': [['2019-1-4', '292'],
          ['2019-8-2', '52'],
          ['2019-3-2', '522']],
         'www.google.com': [['2019-1-2', '102'],
          ['2019-6-2', '162'],
          ['2019-8-5', '591']]})
票数 2
EN

Stack Overflow用户

发布于 2019-08-14 09:26:29

使用dict.setdefault

代码语言:javascript
复制
d = {}
for x, y, z in l:
    d.setdefault(x, []).append([y, z])
print(d)

或者使用单行字典理解:

代码语言:javascript
复制
print({x: [[j, k] for i, j, k in l if i == x] for x, y, z in l})
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57487052

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档