Python 二维列表,用sorted函数怎么多重排序?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 二维列表,用sorted函数怎么多重排序?相关的知识,希望对你有一定的参考价值。

多重排序中的每一项排序有的是升序,有的是降序

在Python中,使用sorted函数对二维列表进行多重排序可以使用key参数。key参数接收一个函数,该函数接收一个列表元素作为参数,返回一个用于排序的值。可以使用lambda函数来实现多重排序,例如:

sorted_list = sorted(my_list, key=lambda x:(x[1],x[2],x[0]))

这将按第1个元素,第2个元素,第3个元素的顺序对二维列表进行排序。
参考技术A

Python 中可以使用 sorted 函数对二维列表进行多重排序,具体方法如下:

1. 首先定义一个二维列表:

list = [['Bob', 20, 'M'], ['Alice', 18, 'F'], ['John', 22, 'M']]

2. 使用 sorted 函数进行多重排序:

sorted(list, key=lambda x:(x[2],x[1],x[0]))

结果如下:

[['Alice', 18, 'F'], ['John', 22, 'M'], ['Bob', 20, 'M']]

追问

如果各个排序有升↑有降↓呢?比如在这个举例中:
要求以x[1]↑,x[2]↓,x[0]↑的顺序依次多重排序,又该怎么弄?

python中列表删除和多重循环退出

在学习python的时候,会有一些梗非常不适应,在此列举列表删除和多重循环退出的例子:

列表删除里面的坑

比如我们有一个列表里面有很多相同的值,假如:nums=[1,6,6,3,6,2,10,2,100],我想去掉6,可以这样写:

 nums=[1,6,6,3,6,2,10,2,100]
 for n in nums:
     if n==6:
         nums.remove(n)
 nums.sort()
 print(nums)#输出结果:[1, 2, 2, 3, 6, 10, 100]

排序显示后列表中还有一个6,下面是慢动作分解:

index :0,num:1

index :1,num:6
before: [1, 6, 6, 3, 6, 2, 10, 2, 100]

after: [1, 6, 3, 6, 2, 10, 2, 100] 
index :2,num:3
index :3,num:6
before: [1, 6, 3, 6, 2, 10, 2, 100] 
after: [1, 3, 6, 2, 10, 2, 100]
index :4,num:10
index :5,num:2
index :6,num:100
final: [1, 3, 6, 2, 10, 2, 100]

用sort排序后如结果所示第一次循环到6的时候,下标为1,这时删除了index[1]=6,
接着在新列表中继续删除,index[2]=3,就直接略过了新列表中的index[1]=6,所以最终还有一个6

python中多重循环如何退出

我们在进行嵌套循环的时候,需要立刻退出,用break是不行的:

‘‘‘
遇到问题没人解答?小编创建了一个Python学习交流QQ群:579817333 
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
‘‘‘
def fun():
    for i in range(3):
        for i in range(10,13):
            print("inner:",i)
            if i==12:
              # return
                break#会循环输出3次
        print("outter:",i)
    print(‘end‘)
fun()

输出结果如下:

inner: 10
inner: 11
inner: 12
outter: 12
inner: 10
inner: 11
inner: 12
outter: 12
inner: 10
inner: 11
inner: 12
outter: 12
end

解决办法:直接return或者加变量控制

‘‘‘
遇到问题没人解答?小编创建了一个Python学习交流QQ群:579817333 
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
‘‘‘
def fun():
    for i in range(3):
        for i in range(10,13):
            print("inner:",i)
            if i==12:
              return
                #break#会循环输出3次
        print("outter:",i)
    print(‘end‘)
fun()

1 inner: 10 2 inner: 11 3 inner: 12

break 规范都是只结束最近一层循环的。python 在for用的是迭代器循环,i in range(3)并不受i==12影响而结束最外层循环,

因为i = 12也只是i的一个临时指向而已,python一切皆对象决定,i只是指向值为12的对象的id,

break到外层循环会重新指向迭代器range(3)的一个对象。

所以多重循环用break不能退出,我们可以用return来解决。

以上是关于Python 二维列表,用sorted函数怎么多重排序?的主要内容,如果未能解决你的问题,请参考以下文章

python 二维数组排序

Vector容器 二维数组sort()排序

Python对列表排序函数sort()和reverse()的讲解

python中多重目录中的包引用怎么样?

Python中对列表进行排序的方法都有哪些呢?

关于python的sorted函数的问题?