V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
pinkman
V2EX  ›  Python

请问这段代码(为列表中的字典元素去重复)如何能写成列表表达式呢

  •  
  •   pinkman · 2013-08-21 22:51:04 +08:00 · 5551 次点击
    这是一个创建于 4118 天前的主题,其中的信息可能已经有所发展或是发生改变。
    >>> t1 = [{'a':1},{'a':1},{'b':2}]
    >>> t11 = []
    >>> for i in t1:
    if i not in t11:
    t11.append(i)
    9 条回复    1970-01-01 08:00:00 +08:00
    VYSE
        1
    VYSE  
       2013-08-21 23:01:11 +08:00
    你把{}变成()
    t1 = [('a',1),('a',1),('b',2)]
    一个dict不久搞定了?
    d1 = dict(t1)
    ipconfiger
        2
    ipconfiger  
       2013-08-21 23:08:00 +08:00   ❤️ 1
    [{k:v} for k,v in dict([list(d.iteritems())[0] for d in t1]).iteritems()]

    搞定收工
    pinkman
        3
    pinkman  
    OP
       2013-08-21 23:12:01 +08:00
    @ipconfiger 厉害!但看起来好难懂啊,我还是用最简单我原来的方法算了
    saturnisbig
        4
    saturnisbig  
       2013-08-21 23:13:35 +08:00
    ipconfiger
        5
    ipconfiger  
       2013-08-21 23:51:29 +08:00
    @pinkman 随手写的写复杂了点
    [{k:v} for k,v in dict([d.items()[0] for d in t1]).items()]
    简化后就这样了,其实dict([d.items()[0] for d in t1]).items() 以外的部分纯粹是为了把列表内还原成一个个字典
    jokaye
        6
    jokaye  
       2013-08-22 09:35:06 +08:00   ❤️ 1
    [t11.append(t) for t in t1 if t not in t11] ?
    pinkman
        7
    pinkman  
    OP
       2013-08-22 09:47:23 +08:00
    @jokaye 原来如此,还是需要先生成个t11 = []的空字典,随后的list表达式就好写了,之前我就一直在想不自己先定义t11(因为考虑到列表表达式本来就要生成列表),所以才老是想不出来,现在清楚了,感谢jokaye
    mengzhuo
        8
    mengzhuo  
       2013-08-22 11:37:00 +08:00
    [t11.append(t) for t in l if t not in t11]
    1000000 loops, best of 3: 793 ns per loop
    # 不过话说这么个复杂度是2n吧

    [dict(t) for t in set([tuple(d.items()) for d in l])]
    100000 loops, best of 3: 9.25 us per loop

    [{k:v} for k,v in dict([list(d.iteritems())[0] for d in t1]).iteritems()]
    100000 loops, best of 3: 10.4 us per loop

    [{k:v} for k,v in dict([d.items()[0] for d in t1]).items()]
    100000 loops, best of 3: 5.01 us per loop
    # 这个很漂亮

    ---------------------------

    升级一下测试:
    t2 = [{random.randint(0, 4095):1} for k in xrange(9999)]
    len([d for d in t2 if t2.count(d) > 1]) # 这次随机出9144项重复的

    [t22.append(t) for t in t2 if t not in t22]
    1 loops, best of 3: 1.54 s per loop
    # 直接跪了 = =

    [dict(t) for t in set([tuple(d.items()) for d in t2])]
    10 loops, best of 3: 21.9 ms per loop

    [{k:v} for k,v in dict([list(d.iteritems())[0] for d in t2]).iteritems()]
    10 loops, best of 3: 26 ms per loop

    [{k:v} for k,v in dict([d.items()[0] for d in t2]).items()]
    100 loops, best of 3: 11.4 ms per loop
    # 用iter,会更好
    [{k:v} for k,v in dict([d.items()[0] for d in t2]).iteritems()]
    100 loops, best of 3: 10.7 ms per loop
    mengzhuo
        9
    mengzhuo  
       2013-08-22 11:57:21 +08:00
    我觉得黑魔法了的一种方法:
    [{k:v} for k,v in dict([d.iteritems().next() for d in t2]).iteritems()]
    100 loops, best of 3: 10.4 ms per loop

    不过性能没啥提升了,还是@ipconfiger 的iter版给力了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1015 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 19:52 · PVG 03:52 · LAX 11:52 · JFK 14:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.