鱼C论坛

 找回密码
 立即注册
查看: 1454|回复: 12

[已解决]如何将列表中重复项合并,并删除合并后的项?

[复制链接]
发表于 2018-4-1 09:49:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 2OLEGEND 于 2018-4-1 10:33 编辑

有这样一个列表,其中的元素是由列表构成的列表

list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]

如何将其变为

list2 = [[6, 6],  [7, 11],  [12, 1], [155, 4]]
我写了个代码,只能将其重复项合并,而不知道该如何删除合并后的项,请各位老师赐教!


  1. list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]

  2. for i in range(len(list1)):
  3.     if i < len(list1) - 1:
  4.         
  5.         for j in range(i + 1, len(list1)):
  6.             if list1[i][0] == list1[j][0]:
  7.                 list1[i][1] +=list1[j][1]
  8. print(list1)
复制代码


这个代码输出的结果为:

list1 = [[6, 6], [6, 3], [7, 11], [7, 9], [7, 5], [12, 1], [155, 4]]
最佳答案
2018-4-1 10:42:15
  1. list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]
  2. target=[]
  3. dict1={}
  4. for each in list1:
  5.     if each[0] not in dict1:
  6.         dict1[each[0]]=each[1]
  7.     else:
  8.         dict1[each[0]]+=each[1]
  9. for each in dict1:
  10.     target.append([each,dict1[each]])   
  11. print(target)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-1 10:03:55 | 显示全部楼层
  1. for each in list1:
  2.     if list1.count(each)>1:
  3.         list1.remove(each)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-1 10:14:29 | 显示全部楼层

谢谢哥们,不过有问题啊。这是一个嵌套的列表,您这样的方法还是没有实现我想要的结果,并不是对每一个子列表的第0个元素进行处理!

不过还是谢谢您!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 10:19:12 | 显示全部楼层
2OLEGEND 发表于 2018-4-1 10:14
谢谢哥们,不过有问题啊。这是一个嵌套的列表,您这样的方法还是没有实现我想要的结果,并不是对每一个子 ...

没懂啊,其他元素有重复也可以啊?你的什么运行结果
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-1 10:20:14 | 显示全部楼层
本帖最后由 2OLEGEND 于 2018-4-1 10:34 编辑
塔利班 发表于 2018-4-1 10:19
没懂啊,其他元素有重复也可以啊?你的什么运行结果


有这样一个列表,其中的元素是由列表构成的列表

list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]

如何将其变为

list2 = [[6, 6],  [7, 11],  [12, 1], [155, 4]]

这是我想要的结果
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 10:22:10 | 显示全部楼层
2OLEGEND 发表于 2018-4-1 10:20
有这样一个列表,其中的元素是由列表构成的列表

list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], ...

你这算法怎么来的,6,3两个怎么出的6,9
7的2,4,5倒是可以出11,不知道你要怎么算
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-1 10:33:41 | 显示全部楼层
塔利班 发表于 2018-4-1 10:22
你这算法怎么来的,6,3两个怎么出的6,9
7的2,4,5倒是可以出11,不知道你要怎么算

写错了,应该是
list2 = [[6, 6],  [7, 11],  [12, 1], [155, 4]],
不好意思
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 10:39:01 From FishC Mobile | 显示全部楼层
一种思路:
建立一个字典
遍历列表,取出每个子列表的第一个元素,放到一个列表中,用set去重复
将上述的集合作为键值,遍历原始大列表,匹配第一的元素,同键则将其值相加
最后根据需求将字典转为列表即可
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 10:42:15 | 显示全部楼层    本楼为最佳答案   
  1. list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]
  2. target=[]
  3. dict1={}
  4. for each in list1:
  5.     if each[0] not in dict1:
  6.         dict1[each[0]]=each[1]
  7.     else:
  8.         dict1[each[0]]+=each[1]
  9. for each in dict1:
  10.     target.append([each,dict1[each]])   
  11. print(target)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-1 10:46:22 | 显示全部楼层
本帖最后由 2OLEGEND 于 2018-4-1 10:48 编辑

谢谢老哥了!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-1 10:48:55 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 10:51:41 | 显示全部楼层

客气。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-1 16:18:02 | 显示全部楼层
我也仿照写一个:
  1. list1 = [[6, 3], [6, 3], [7, 2], [7, 4], [7, 5], [12, 1], [155, 4]]
  2. target=[]
  3. dict1={}
  4. for i in range(len(list1)):
  5.     if list1[i][0] not in dict1:
  6.         dict1[list1[i][0]]=len(dict1)
  7.         target.append(list1[i])
  8.     else:
  9.         target[dict1[list1[i][0]]][1] += list1[i][1]
  10. print(target)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-10-1 03:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表