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
cxyfreedom
V2EX  ›  Python

关于 Python 使用 sort 排序的一个问题

  •  
  •   cxyfreedom · 2016-08-04 18:46:28 +08:00 · 2576 次点击
    这是一个创建于 3036 天前的主题,其中的信息可能已经有所发展或是发生改变。

    有这样一个 list :['1y','3m','1m','7d','5d','1d','12h','6h','3h']

    其中 y 表示年, m 表示月, d 表示天, h 表示小时,前面的数字表示对应的时间

    问如何用 sort 在一行内按照年>月>天>小时或者反过来的顺序进行排序?

    12 条回复    2016-08-06 17:12:50 +08:00
    WangYanjie
        1
    WangYanjie  
       2016-08-04 19:01:01 +08:00
    强行要一行!
    sorted(a, key=lambda x: ({'h': 0, 'd': 1, 'm': 2, 'y': 3}[x[-1]], int(x[:-1])))
    fcicq
        2
    fcicq  
       2016-08-04 19:03:22 +08:00
    @WangYanjie 显然 25h > 1d 就错了.
    Yinz
        3
    Yinz  
       2016-08-04 19:13:25 +08:00
    @fcicq 这个列表元素应该保证合法吧,不然没办法判断 1m > 30d 还是 1m == 30d
    cxyfreedom
        4
    cxyfreedom  
    OP
       2016-08-04 19:25:49 +08:00 via iPhone
    @Yinz 但是像 @fcicq 说的那种情况也是存在的
    Yinz
        5
    Yinz  
       2016-08-04 19:30:37 +08:00
    @cxyfreedom 那是按照 1y = 12m = 12*30d = 12*30*24h 的话,

    sorted(a, key=lambda x: {'h': 1, 'd': 24, 'm': 720, 'y': 8640}[x[-1]]*int(x[:-1]))
    9hills
        6
    9hills  
       2016-08-04 19:31:44 +08:00
    为啥强行要一行,比较优雅是两行

    In [17]: a=['1y','3m','1m','7d','5d','1d','12h','6h','3h']

    In [18]: k=dict(y=365*24,m=30*24,d=24,h=1)

    In [19]: sorted(a, key=lambda x:int(x[:-1])*k[x[-1]], reverse=True)
    Out[19]: ['1y', '3m', '1m', '7d', '5d', '1d', '12h', '6h', '3h']

    你把 k 定义到 lambda 中就是一行了。。。

    In [20]: sorted(a, key=lambda x:int(x[:-1])*dict(y=365*24,m=30*24,d=24,h=1)[x[-1]], reverse=True)
    Out[20]: ['1y', '3m', '1m', '7d', '5d', '1d', '12h', '6h', '3h']
    xiaket
        7
    xiaket  
       2016-08-04 19:37:18 +08:00
    desc_in_hours = lambda item: int(item[:-1]) * {'y': 365.24*24, 'm': 365.24*2, 'w': 7*24, 'd': 24, 'h': 1}.get(item[-1], 0)
    cxyfreedom
        8
    cxyfreedom  
    OP
       2016-08-04 19:37:54 +08:00
    @9hills 面试被问到的时候说一行,我一时间没想出来。 key 的判断方法还是没掌握好,谢谢你的解答:)
    xiaket
        9
    xiaket  
       2016-08-04 19:38:48 +08:00
    @9hills 好吧,和你撞车了...
    cxyfreedom
        10
    cxyfreedom  
    OP
       2016-08-04 19:40:56 +08:00
    @Yinz @xiaket 谢谢解答:)
    ruanimal
        11
    ruanimal  
       2016-08-05 09:02:31 +08:00
    sorted(tlist, key=lambda x: {'y': 1*365*24, 'm': 30*24, 'd': 24, 'h':1}[x[-1]] * int(x[:-1]))
    Stumioga
        12
    Stumioga  
       2016-08-06 17:12:50 +08:00
    @9hills k=dict(y=365*24,m=30*24,d=24,h=1)
    这句是啥?是创建字典?我这怎么提示语法错误,y m d 加上引号还是不行?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5481 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 08:45 · PVG 16:45 · LAX 00:45 · JFK 03:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.