zoukankan      html  css  js  c++  java
  • 深入Python(1): 字典排序 关于sort()、reversed()、sorted()

    http://www.cnblogs.com/BeginMan/p/3193081.html

     

    一、Python的排序

    1、reversed()

    这个很好理解,reversed英文意思就是:adj. 颠倒的;相反的;(判决等)撤销的

    print list(reversed(['dream','a','have','I']))
    #['I', 'have', 'a', 'dream']

    2、让人糊涂的sort()与sorted()

    在Python 中sorted是内建函数(BIF),而sort()是列表类型的内建函数list.sort()。

    sorted()

    sorted(iterable[, cmp[, key[, reverse]]])

    Return a new sorted list from the items in iterable.

    The optional arguments(可选参数) cmp, key, and reverse have the same meaning as those for the list.sort() method (described in section Mutable Sequence Types).

    cmp specifies(指定) a custom comparison function of two arguments (iterable(可迭代的) elements) which should return a negative(复数), zero or positive(正数) number depending on whether the first argument is considered smaller than, equal to, or larger than the second argument: cmp=lambda x,y: cmp(x.lower(), y.lower()). The default value is None.

    key specifies a function of one argument that is used to extract a comparison key from each list element: key=str.lower. The default value is None (compare the elements directly).

    reverse is a boolean value. If set to True, then the list elements are sorted as if each comparison were reversed.

    #字符串排序使用是字典序,而非字母序
    """sorted()按照字典序排序"""
    lis = ['a','c','z','E','T','C','b','A','Good','Tack']
    print sorted(lis)   #['A', 'C', 'E', 'Good', 'T', 'Tack', 'a', 'b', 'c', 'z']

    关于字典序:

    可参考百度百科。http://baike.baidu.com/view/4670107.htm

    根据ASCII排,具体如下:
    0-9(对应数值48-59);
    A-Z(对应数值65-90);
    a-z(对应数值97-122);

    ------------
    标准序: 短在前,长在后,等长的依次比字母,
    如to < up < cap < cat < too < two <boat < boot < card
    字典序: 依次比字母,
    如boat < boot <cap < card < cat < to < too< two < up

    更有甚者说字典序就是字典的排序,像字典一样。我一直没有找到权威的说明,什么是字典序????求答案!!

    sort()

    s.sort([cmp[, key[, reverse]]])

    三、Python的字典排序

    1、关于Python字典的一些特征

    无序:

    字典,形如 dic = {'a':1 , 'b':2 , 'c': 3},字典中的元素没有顺序,所以dic[0]是有语法错误的。

    无重:

    不可以有重复的键值,所以 dic.add['c'] = 4后,字典变成 {'a':1 , 'b':2 , 'c': 4}.

    2、根据“键”或“键值”进行不同顺序的排序

    函数原型:sorted(dic,value,reverse)

    解释:dic为比较函数,value 为排序的对象(这里指键或键值),

    reverse:注明升序还是降序,True--降序,False--升序(默认)

    3、例子:

    dic = {'a':31, 'bc':5, 'c':3, 'asd':4, '33':56, 'd':0}
    想把dic的value按照从大到小排序(value都是整数)。

    dic = {'a':31, 'bc':5, 'c':3, 'asd':4, '33':56, 'd':0}
    print sorted(dic.iteritems(), key=lambda d:d[1], reverse = False )  
    #[('d', 0), ('c', 3), ('asd', 4), ('bc', 5), ('a', 31), ('33', 56)]

    解释如下:

    (1)、dic.iteritems(),返回字典键值对的元祖集合

    复制代码
    print dic.iteritems()   #<dictionary-itemiterator object at 0x00B71A80>
    
    for obj in dic.iteritems():
        print obj,obj[0],obj[1]
        
    #('a', 31) a 31
    #('c', 3) c 3
    #('d', 0) d 0
    #('bc', 5) bc 5
    #('33', 56) 33 56
    #('asd', 4) asd 4
    复制代码

    (2)、关于排序对象

    上述已经说过,value(或key)为排序的对象(这里指键或键值),然而为什么使用lambda函数呢,这里请参阅:点击阅读

    key=lambda d:d[1] 是将键值(value)作为排序对象。

    key = lambda d:d[1]
    for i in dic.iteritems():
        print key(i),   #输出31 3 0 5 56 4,这些都是字典dic的值

    如果选择 key = lambda d:d[0],则选择【键Key】作为排序对象。

    (3)、reverse

    reverse 是否反向,reverse=Ture表示反向。

    (4)、注意:

    sorted(dic.iteritems(), key=lambda d:d[1], reverse = False )将每一项dic.iteritems()键值对的元祖进行迭代,每一项都作为参数传入key()函数(我说的是这个:key=lambda d:d[1],)中。

     4、回顾

    lis = ['a','bc','c','asd','33','d']
    print sorted(lis)   #['33', 'a', 'asd', 'bc', 'c', 'd']
    依次比字母, 如boat < boot <cap < card < cat < to < too< two < up

    5.问题

    具体实例可参考:[**python的排序函数sort,sorted在列表排序和字典排序中的应用详解和举例**](http://wangwei007.blog.51cto.com/68019/1100742)

    现在有这种情况,排序中排序。如大题号排序,然后大题对应的小题号也排序,如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    lis = [{'Big':3, 'small':2},{'Big':3, 'small':4},{'Big':2, 'small':2}, {'Big':3, 'small':1},{'Big':2, 'small':1},{'Big':1, 'small':1}]
     
    # 大题号排序
    li = sorted(lis, key=lambda s: s['Big'])
     
    # 输出:
    #[{'small': 1, 'Big': 1}, {'small': 2, 'Big': 2}, {'small': 1, 'Big': 2}, {'small': 2, 'Big': 3}, {'s
    mall': 4, 'Big': 3}, {'small': 1, 'Big': 3}]
     
    # 小题号排序:
    sort_ff = []
    no = set([i['Big'] for i in li])
    for obj in no:
    li_ = []
    for i in ff:
    if i['Big'] == obj:
    li_.append(i)
    l = sorted(li_, key=lambda s: s['small'])
    for j in l:
    sort_ff.append(j)
     
    # 输出结果:
    [{'small': 1, 'Big': 1}, {'small': 1, 'Big': 2}, {'small': 2, 'Big': 2}, {'small': 1, 'Big': 3}, {'small': 2, 'Big': 3}, {'small': 4, 'Big': 3}]


    善用sort() 或 sorted(), a.sort() 已改变其结构,b = a.sort() 是错误的写法! 而 sorted(a, ...)并没有改变a的结构。

    ======================================

      1. #-*- encoding=utf-8 -*-  
      2.   
      3. import operator  
      4. #按字典值排序(默认为升序)  
      5. x = {1:2, 3:4, 4:3, 2:1, 0:0}  
      6. sorted_x = sorted(x.iteritems(), key=operator.itemgetter(1))  
      7. print sorted_x  
      8. #[(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)]  
      9. #如果要降序排序,可以指定reverse=True  
      10. sorted_x = sorted(x.iteritems(), key=operator.itemgetter(1), reverse=True)  
      11. print sorted_x  
      12. #[(3, 4), (4, 3), (1, 2), (2, 1), (0, 0)]  
      13. #或者直接使用list的reverse方法将sorted_x顺序反转  
      14. #sorted_x.reverse()  
      15.   
      16. #取代方法是,用lambda表达式  
      17. sorted_x = sorted(x.iteritems(), key=lambda x : x[1])  
      18. print sorted_x  
      19. #[(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)]  
      20. sorted_x = sorted(x.iteritems(), key=lambda x : x[1], reverse=True)  
      21. print sorted_x  
      22. #[(3, 4), (4, 3), (1, 2), (2, 1), (0, 0)]  
      23.   
      24. #包含字典dict的列表list的排序方法与dict的排序类似,如下:  
      25. x = [{'name':'Homer', 'age':39}, {'name':'Bart', 'age':10}]  
      26. sorted_x = sorted(x, key=operator.itemgetter('name'))  
      27. print sorted_x  
      28. #[{'age': 10, 'name': 'Bart'}, {'age': 39, 'name': 'Homer'}]  
      29. sorted_x = sorted(x, key=operator.itemgetter('name'), reverse=True)  
      30. print sorted_x  
      31. #[{'age': 39, 'name': 'Homer'}, {'age': 10, 'name': 'Bart'}]  
      32. sorted_x = sorted(x, key=lambda x : x['name'])  
      33. print sorted_x  
      34. #[{'age': 10, 'name': 'Bart'}, {'age': 39, 'name': 'Homer'}]  
      35. sorted_x = sorted(x, key=lambda x : x['name'], reverse=True)  
      36. print sorted_x  
      37. #[{'age': 39, 'name': 'Homer'}, {'age': 10, 'name': 'Bart'}] 
  • 相关阅读:
    iOS 8 界面设计 PSD 模板(iPhone 6),免费下载
    20个华丽的时间轴例子,寻找网页设计灵感
    Hello.js – Web 服务授权的 JavaScript SDK
    Web 开发人员和设计师必读文章推荐【系列三十】
    Arctext.js
    30套免费的响应式 HTML5 & CSS3 模板下载
    Midnight.js – 实现奇妙的固定头部切换效果
    推荐20个很有帮助的 Web 前端开发教程
    SweetAlert – 替代 Alert 的漂亮的提示效果
    其实每个行业都有各自的辛苦,好的程序员并不累,他们乐此不疲(见过太多在职位事业、人生方向上随转如流的人,累了疲乏了就去做别的事情了。必须有自己的坚守和立足的点,自我驱动,否则沦为在别人的体制制度中被驱赶一生)good
  • 原文地址:https://www.cnblogs.com/kungfupanda/p/5152759.html
Copyright © 2011-2022 走看看