码迷,mamicode.com
首页 > 编程语言 > 详细

Python 高阶函数 -- Sorted

时间:2018-08-12 15:50:05      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:ber   strong   学生   lower   ini   return   ref   key   排序   

详细内容请参考廖雪峰官网,此处只是一些摘抄,心得与练习的coding。

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

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

     

  2. sorted()函数也是一个高阶函数,它还可以接收一个key函数来实现自定义的排序,例如按绝对值大小排序:
    >>> sorted([36, 5, -12, 9, -21], key=abs)
    [5, 9, -12, -21, 36]

     

  3. 这里必须强调的是sorted只会把第一个参数list的元素逐个传入到key指定的函数中,并不是把整个List传入。
  4. 要进行反向排序,不必改动key函数,可以传入第三个参数reverse=True
    >>> sorted([bob, about, Zoo, Credit], key=str.lower, reverse=True)
    [Zoo, Credit, bob, about]
  5. sorted()排序的关键在于实现一个映射函数。
  6. 练习
    1.  假设我们用一组tuple表示学生名字和成绩:
      L = [(‘Bob‘, 75), (‘Adam‘, 92), (‘Bart‘, 66), (‘Lisa‘, 88)]
      

      请用sorted()对上述列表分别按名字排序:

      # -*- coding: utf-8 -*-
      L = [(Bob, 75), (Adam, 92), (Bart, 66), (Lisa, 88)]
      def by_name(t):
          return t[0]
      
      L2 = sorted(L, key=by_name)
      print(L2)

       

    2. 再按成绩从高到低排序:
      # -*- coding: utf-8 -*-
      L = [(Bob, 75), (Adam, 92), (Bart, 66), (Lisa, 88)]
      def by_score(t):
          return t[1]
      
      L2 = sorted(L, key=by_score)
      print(L2)

       

Python 高阶函数 -- Sorted

标签:ber   strong   学生   lower   ini   return   ref   key   排序   

原文地址:https://www.cnblogs.com/ChrisK/p/9462846.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!