文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

关于Python排序sort()函数和sorted()函数

2023-05-16 14:22

关注

前言:

        上一篇讲了Python排序问题中比较经典的三个方法,(链接:关于Python排序问题(冒泡/选择/插入)这一期来讲如何利用Python中的内置函数去实现直接排序,其中内容包括sort()函数和sorted()函数,这里我会一一介绍。(对象依然是列表list)

1.sort() 函数

语法:

list.sort(cmp=None,key=None,reverse=False)

参数说明:

cmp:是用于比较函数(一般是阿斯克码大小进行比较),比较对象是由key来决定的,一般不写,系统默认。

key:是用来比较的元素对象,这里是传入一个只有一个参数的函数,具体元素在可迭代对象中,这里可以指定可迭代对象中的一个元素为标准

reverse:意思是倒置,这个是一个布尔变量,意思是是否为降序,如果不填就默认为False(升序排序),如果填入了True就为降序排序

返回值

这个函数没有返回值,是直接对列表进行排序处理

 示例1:阿斯克码比较

import random as r
if __name__=='__main__':
    li=[i for i in range(1,11)]
    r.shuffle(li)
    print('排序前:',li)
    li.sort()
    print('排序后:',li)
#输出结果:排序前: [5, 9, 4, 3, 10, 2, 8, 6, 1, 7]
#         排序后: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
import random as r
if __name__=='__main__':
    li=['b','c','w','q','a','g','h']
    r.shuffle(li)
    print('排序前:',li)
    li.sort()
    print('排序后:',li)
#输出结果:排序前: ['h', 'a', 'g', 'w', 'b', 'q', 'c']
#         排序后: ['a', 'b', 'c', 'g', 'h', 'q', 'w']

示例2:(设置reverse,由大到小排序)

import random as r
if __name__=='__main__':
    li=[i for i in range(1,19,2)]
    r.shuffle(li)
    print('排序前:',li)
    li.sort(reverse=True)
    print('排序后:',li)
#输出结果:排序前: [9, 1, 3, 15, 13, 17, 11, 5, 7]
#         排序后: [17, 15, 13, 11, 9, 7, 5, 3, 1]

示例3:基于key排序(传入一个参数)

(1)写法1

import random as r
def lam(temp):
    return temp[1]
if __name__=='__main__':
    li=[('李信',5),('李华',1),('李白',2),('韩信',4),('瑶',6)]
    r.shuffle(li)
    print('排序前:',li)
    li.sort(key=lam)
    print('排序后:',li)
#输出结果:排序前: [('瑶', 6), ('李华', 1), ('李信', 5), ('李白', 2), ('韩信', 4)]
#         排序后: [('李华', 1), ('李白', 2), ('韩信', 4), ('李信', 5), ('瑶', 6)]

 (2)写法2

import random as rif __name__=='__main__':    li=[('李信',5),('李华',1),('李白',2),('韩信',4),('瑶',6)]    r.shuffle(li)    print('排序前:',li)    li.sort(key=lambda x:x[1])    print('排序后:',li)

通过设置key参数,我们可以自定义排序对象,这时候可以去实现列表里面的序列(元组等)进行排序

示例4:key的其他应用

import random as r
if __name__=='__main__':
    li=[('李信',5),('李华',1),('李白',2),('韩信',4),('瑶',6)]
    r.shuffle(li)
    print('排序前:',li)
    li.sort(key=lambda x:x[1])
    print('排序后:',li)

这种排序是按照二次函数y=x^2-8x+6 的单调性去排序的,key的用法很灵活。

2.sorted() 函数

语法:

sorted(literable,cmp=None,key=None,reverse=False)

参数:

literable:这个是表示可迭代对象,包括列表,元组,有序序列等等……

说明:这个函数的功能比sort()函数的功能更加强大,这个函数是可以对可迭代对象进行排序,而sort() 函数只能作用于列表中

返回值:这个函数的返回值是一个排序好了的列表,原来的可迭代对象内容是不会被修改的,而sort()函数是直接把原来的列表排序修改

示例:

import random as r
if __name__=='__main__':
    li=[i for i in range(1,11)]
    r.shuffle(li)
    print('排序前:',li)
    new_li=sorted(li)
    print('原列表:',li)
    print('排序后new:',new_li)
 
#输出结果:排序前: [6, 3, 4, 8, 10, 1, 5, 9, 2, 7]
#         原列表: [6, 3, 4, 8, 10, 1, 5, 9, 2, 7]  
#         排序后new: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

可以看出原来的列表是没有被修改的。

到此这篇关于关于Python排序sort()函数和sorted()函数的文章就介绍到这了,更多相关Python排序sort()和sorted()函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯