Python 高级特性之 sorted( )

本文详细介绍了Python内置sorted()函数的使用方法,包括如何对列表进行排序、实现倒序排序以及忽略大小写排序。通过自定义比较函数,用户能够灵活地对不同类型的数据进行排序。

sorted() 函数接收两个参数, 一个是序列, 一个是函数 (参数顺序和 map/reduce/filter 相反).

python 内置的 sorted() 函数就可以对 list 进行排序:

sorted([36, 5, 12, 9, 21])
>>>[5, 9, 12, 21, 36]

如果想实现倒序排序, 则可以自己写比较函数, 然后做为 sorted() 的第二个参数.
通常规定, 对于两个元素 x 和y:

  • 如果认为 x < y, 则返回 -1
  • 如果认为 x == y, 则返回 0
  • 如果认为 x > y, 则返回 1
def reversed_cmp(x, y):
    if x > y:
        return -1
    if x < y:
        return 1
    return 0

传入自定义的比较函数 reversed_cmp,就可以实现倒序排序:

 sorted([36, 5, 12, 9, 21], reversed_cmp)
>>>[36, 21, 12, 9, 5]

我们再看一个字符串排序的例子:

sorted(['bob', 'about', 'Zoo', 'Credit'])
>>>['Credit', 'Zoo', 'about', 'bob']

默认情况下, 对字符串排序, 是按照 ASCII 的大小比较的, 也就是说, 它是区分大小写的, 由于’Z’ < ‘a’, 所以大写字母 Z 会排在小写字母 a 的前面.

现在, 我们提出排序应该忽略大小写, 按照字母序排序, 要实现这个算法, 只要我们定义出忽略大小写的比较函数就可以:

def cmp_ignore_case(s1, s2):
    u1 = s1.upper()
    u2 = s2.upper()
    if u1 < u2:
        return -1
    if u1 > u2:
        return 1
    return 0

忽略大小写来比较两个字符串, 实际上就是先把字符串都变成大写(或者都变成小写)再比较.

这样, 我们给 sorted() 传入上述比较函数, 即可实现忽略大小写的排序:

sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
>>>['about', 'bob', 'Credit', 'Zoo']
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值