Flask-SQLAlchemy获取字段里去掉重复的数据

注意:可排序的列表内元素不可以是字典等复杂数据类型

比较容易记忆的是用内置的''set''

l1 = ['b','c','d','b','c','a','a']
l2 = list(set(l1))
print l2

还有一种据说速度更快的,没测试过两者的速度差别

l1 = ['b','c','d','b','c','a','a']
l2 = {}.fromkeys(l1).keys()
print l2

这两种都有个缺点,祛除重复元素后排序变了:

['a', 'c', 'b', 'd']

如果想要保持他们原来的排序:

用list类的sort方法

l1 = ['b','c','d','b','c','a','a']
l2 = list(set(l1))
l2.sort(key=l1.index)
print l2

也可以这样写

l1 = ['b','c','d','b','c','a','a']l2 = sorted(set(l1),key=l1.index)print l2

也可以用遍历(常用)

l1 = ['b','c','d','b','c','a','a']
l2 = []for i in l1: 
   if not i in l2: 
       l2.append(i)
print l2

上面的代码也可以这样写

l1 = ['b','c','d','b','c','a','a']
l2 = [][l2.append(i) 
     for i in l1 if not i in l2]
print l2

这样就可以保证排序不变了:

['b', 'c', 'd', 'a']

白首为功名。旧山松竹老,阻归程。欲将心事付瑶琴。知音少,弦断有谁听?
---赖忠标

参考文档:http://www.cnblogs.com/lazb/p/5444154.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,348评论 0 33
  • 教你如何迅速秒杀掉:99%的海量数据处理面试题 本文经过大量细致的优化后,收录于我的新书《编程之法》第六章中,新书...
    Helen_Cat阅读 12,114评论 1 39
  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 5,227评论 0 1
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,583评论 0 52
  • 一 小e在3月7日女生节那天给我发视频说“我恋爱了,对象正是我的男神哦。”,手机那端的她又蹦又跳的,碰到人就说“她...
    一路向北去你的季节阅读 3,207评论 14 5