广告位联系
返回顶部
分享到

Python中的list.sort()方法和函数sorted(list)

python 来源:互联网 作者:佚名 发布时间:2022-08-26 11:02:16 人浏览
摘要

1.sort()方法 sort()是列表的方法,修改原列表使得它按照大小排序,没有返回值,返回None 1 2 3 4 5 6 7 8 In [90]: x = [4, 6, 2, 1, 7, 9] In [91]: x.sort() In [92]: x Out[92]: [1, 2, 4, 6, 7, 9] In [98]: aa = x.sort() In

1.sort()方法

sort()是列表的方法,修改原列表使得它按照大小排序,没有返回值,返回None

1

2

3

4

5

6

7

8

In [90]: x = [4, 6, 2, 1, 7, 9]

 

In [91]: x.sort()

 

In [92]: x

Out[92]: [1, 2, 4, 6, 7, 9]

In [98]: aa = x.sort()

In [99]: aa #  返回None

2.sorted()函数

sorted()是函数,不改变列表,重新生成一个按大小排序的列表

1

2

3

4

5

6

In [94]: a = sorted(x)

In [95]: a

Out[95]: [1, 2, 4, 6, 7, 9]

 

In [96]: x

Out[96]: [4, 6, 2, 1, 7, 9]

3.可选参数

列表sort方法还有两个可选参数:key和reverse

1

2

3

4

5

6

7

8

9

## 1、key在使用时必须提供一个排序过程总调用的函数:

x = ['mmm', 'mm', 'mm', 'm']

x.sort(key=len)

print(x)  # 输出 ['m', 'mm', 'mm', 'mmm']

 

## 2、reverse实现降序排序,需要提供一个布尔值:

y = [3, 2, 8, 0, 1]

y.sort(reverse=True)

print(y)  # [8, 3, 2, 1, 0]

4.优先级排序

1

2

3

4

5

6

7

8

9

## 1、key在使用时必须提供一个排序过程总调用的函数:

x = ['mmm', 'mm', 'mm', 'm']

x.sort(key=len)

print(x)  # 输出 ['m', 'mm', 'mm', 'mmm']

 

## 2、reverse实现降序排序,需要提供一个布尔值:

y = [3, 2, 8, 0, 1]

y.sort(reverse=True)

print(y)  # [8, 3, 2, 1, 0]

输出:

不在group 1 8
在group 0 3
不在group 1 1
在group 0 2
在group 0 5
不在group 1 4
在group 0 7
不在group 1 6
[2, 3, 5, 7, 1, 4, 6, 8]

这个函数之所以能够正常运作,是基于下列三个原因:

  • Python支持闭包( closure):闭包是一种定义在某个作用域中的函数,这种函数引用了那个作用域里面的变量。helper函数之所以能够访问sort_priority的group参数,原因就在于它是闭包。
  • Python的函数是一级对象(first-class object),也就是说,我们可以直接引用函数、把函数赋给变量、把函数当成参数传给其他函数,并通过表达式及if语句对其进行比较和判断,等等。于是,我们可以把 helper这个闭包函数,传给sort方法的key参数。
  • Python使用特殊的规则来比较两个元组°。它首先比较各元组中下标为0的对应元素,如果相等,再比较下标为1的对应元素,如果还是相等,那就继续比较下标为2的对应元素,依次类推。

5.闭包修改标志变量

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

def sort_priority2(values,group):

    found = False

    def helper(x):

        if x in group:

            found = True

            return (0,x)

        return (1,x)

    values.sort(key=helper)

    return found

numbers = [8,3,1,2,5,4,7,6]

group = [8,5,2,3,4,7,9]

found = sort_priority2(numbers,group)

print('最后的numbers',numbers)

print("found",found)

输出:最后的numbers [2, 3, 4, 5, 7, 8, 1, 6]

found False

6.闭包修改标志变量2, 新增nonlocal

下面用nonlocal来实现这个函数:

Python 3中有一种特殊的写法,能够获取闭包内的数据。我们可以用nonlocal语句来表明这样的意图,也就是:给相关变量赋值的时候,应该在上层作用域中查找该变量。

nonlocal的唯一限制在于,它不能延伸到模块级别,这是为了防止它污染全局作用域。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

def sort_priority2(values,group):

    found = False

    def helper(x):

        if x in group:

            nonlocal found

            found = True

            return (0,x)

        return (1,x)

    values.sort(key=helper)

    return found

numbers = [8,3,1,2,5,4,7,6]

group = [8,5,2,3,4,7,9]

found = sort_priority2(numbers,group)

print('最后的numbers',numbers)

print("found",found)

输出:最后的numbers [2, 3, 4, 5, 7, 8, 1, 6]

found True

nonlocal语句清楚地表明:如果在闭包内给该变量赋值,那么修改的其实是闭包外那个作用域中的变量。这与global语句互为补充,global用来表示对该变量的赋值操作,将会直接修改模块作用域里的那个变量。

然而,nonlocal也会像全局变量那样,遭到滥用,所以,建议大家只在极其简单的函数里使用这种机制。nonlocal的副作用很难追踪,尤其是在比较长的函数中,修饰某变量的nonlocal语句可能和修改该变量的赋值操作离得比较远,从而导致代码更加难以理解。

如果使用nonlocal的那些代码,已经写得越来越复杂,那就应该将相关的状态封装成辅助类(helper class)。下面定义的这个类,与nonlocal所达成的功能相同。它虽然有点长,但是理解起来相当容易(其中有个名叫_call_的特殊方法

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

class Sorter(object):

    def __init__(self,group):

        self.group = group

        self.found = False

    def __call__(self,x):

        if x in self.group:

            self.found = True

            return (0,x)

        return (1,x)

group = [8,5,2,3,4,7,9]

numbers = [8,3,1,2,5,4,7,6]

sorter = Sorter(group)

numbers.sort(key=sorter)

assert sorter.found is True

print(sorter.found)

sorted的关键字排序

1

2

3

4

5

6

7

8

9

10

11

12

13

student_tuples = [

    ('john', 'A',20, 15),

    ('jane', 'B',21, 12),

    ('dave', 'B', 22,10),

 ]

print(sorted(student_tuples, key=lambda student: student[0]))   # sort by age

# [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]

 

L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]

def f(x):

    return len(x)

L.sort(key=f) #reverse = True #怎样在此处天加速reverse

print (L)


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/qdPython/article/details/126504256
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计