sorted 内置函数_排序

sorted 内置函数_排序:

在这里插入图片描述


sorted(iterable[,cmp=None,key=None,reverse=False]) 对可迭代对象进行排序,排序好后返回一个新列表。参数如下:
  iterable:可以是:列表、集合、字典、元组、字符串、可迭代的对象...cmp:可以指定一个比较函数,这个函数接收两个参数,具体如下:
          如果第一个参数 小于 第二个参数,返回一个负数,即第一个参数减第二个参数;
          如果第一个参数 等于 第二个参数,返回零,即第一个参数减第二个参数;
          如果第一个参数 大于 第二个参数,返回一个正数,即第一个参数减第二个参数。
  key:可以指定一个函数来排序,函数接收一个参数,用于从列表中依次提取一个元素比较键。默认是None(直接比较元素)。
  reverse:参数是布尔值。False表示升序排序,从小到大排序,也是默认值。True表示降序排序,从大到小排序。
  

例子1:按某个字母排序


d={"zip":9,"name":15,"age":20,"money":100,"xiaoming":"小明"}
print(sorted(d,reverse=False,key=lambda x:x[2]))  #根据每项的第3个字母来比较。
#注:26个字母的顺序是这样的: abcedfghijklmnopqrstuvwxyz

输出结果:

在这里插入图片描述


例子2:按出生日期排序


stuLists = [{'stu_id': 1, 'birthday': '2022-02-10'},{'stu_id': 2, 'birthday': '2021-02-20'}, {'stu_id': 3, 'birthday': '2021-03-10'}]
sortedStuList = sorted(stuLists, key=lambda item: item['birthday'])
print(sortedStuList)

输出结果:

在这里插入图片描述


例子3:随机排序

import random

def fn(item):
    return random.randint(-1,1)

aList=[5,4,8,95,1,100,10,2]
ab = sorted(aList, key=fn, reverse=True)
print(ab)

输出结果(每次都不一样):

在这里插入图片描述

--------------- 结束 ---------------
仅学习。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来为您编写一个模拟 Python 内置函数 sorted() 的函数。代码如下: ```python def my_sorted(iterable, key=None, reverse=False): """ 模拟 Python 内置函数 sorted() :param iterable: 可迭代对象 :param key: 排序依据函数 :param reverse: 是否逆序排序 :return: 排序后的列表 """ # 将可迭代对象转为列表 result = list(iterable) # 如果没有指定排序依据函数,则按元素自身大小进行排序 if key is None: result.sort(reverse=reverse) else: # 使用排序依据函数进行排序 result.sort(key=key, reverse=reverse) return result ``` 这个函数接受三个参数: - `iterable`:需要排序的可迭代对象。 - `key`:排序依据函数,默认为 `None`,即按元素自身大小进行排序。 - `reverse`:是否逆序排序,默认为 `False`。 函数的返回值是排序后的列表。您可以使用如下方式来调用这个函数: ```python # 排序一个列表 my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5] sorted_list = my_sorted(my_list) print(sorted_list) # 按元素的绝对值大小进行排序 sorted_list = my_sorted(my_list, key=abs) print(sorted_list) # 按元素的倒数进行排序 sorted_list = my_sorted(my_list, key=lambda x: 1/x) print(sorted_list) # 逆序排序 sorted_list = my_sorted(my_list, reverse=True) print(sorted_list) ``` 输出结果分别为: ``` [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9] [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9] [9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1] [9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1] ``` 请注意,这个函数并不会改变原来的可迭代对象,而是返回一个新的列表。同时,这个函数的实现方式与 Python 内置函数 sorted() 可能有所不同,但是它们的功能是相同的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值