Python3实现对列表按元组指定列进行排序的方法分析

  

本文实例讲述了Python3实现对列表按元组指定列进行排序的方法。分享给大家供大家参考,具体如下:

  

Python版本:python3。+
  运行环境:Mac OS
  IDE: pycharm

  

Python内建的排序方法

  

1排序方法介绍

  

Python中有2个排序函数,一个是列表内置的排序()方法,另一个是全局的排序()方法

  
  

<代码>排序(iterable,关键=None,反向=False) #返回排好序的新列的表,不改变对象本身,默认升序;相反,真正降序假正序对所有可迭代的对象均有效
  list . sort(关键就<代码>=None,反向=False) #将列表自身进行排序,不返回新列表的对象,默认升序;相反,真正降序假正序

     

2基本的列表排序

  

1) list . sort()就<代码> 排序

        data=https://www.yisu.com/zixun/(5、7、9、3、6, 7, 8, 9, 3、8]   结果=data.sort ()   打印(数据)#结果为[9、8、8、7、6、3,3,5,7,9]   打印(结果)#结果为没有      之前      

2) <代码>排序()排序

        data=https://www.yisu.com/zixun/(5、7、9、3、6, 7, 8, 9, 3、8]=排序结果(数据)   打印(数据)#结果为(5、7、9、3、6,7,8,9,3、8]   打印(结果)#结果为[9、8、8、7、6、3,3,5,7,9]      之前      

3以元组作为列表的元素

  

在默认情况下分类和排序函数接收的参数是元组时,它将会先按元组的第一个元素进行排序再按第二个元素进行排序,再按第三个,第四个…依次排序。
  

  

我们通过一个简单的例子来了解它,以下面这个列表为例:

        data=https://www.yisu.com/zixun/[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))      之前      

我们通过<代码>排序()对它进行排序

        data=https://www.yisu.com/zixun/[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))=排序结果(数据)   打印(数据)#结果为[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))   打印(结果)#结果为[(0,' B ') (0, ' '), (1, ' '), (B), (2, ' '))      之前      

会发现排序后的结果中(0,B)在(0,' ')的前面。这是因为在按元组第一个元素排好之后,将(0,' B ')(0, ' ')再按第二个元素进行排序了,而“B”的ASCII编码比一个小,所以(0,“B”)就排在(0,' ')的前面了。

  

那如何想要让它排序时不分大小写呢?

  

这就要用到这种方法和分类方法里的关键参数了。

  

我们来看一下具体的实现:

        data=https://www.yisu.com/zixun/[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))   #利用参数键来规定排序的规则   结果=排序(数据、关键=λx: x (x [0], [1] .lower ()))   打印(数据)#结果为[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))   打印(结果)#结果为[(0,' '),(0,' B '), (1, ' '), (B), (2, ' '))      之前      

其中的<代码>λx: (x [0], [1] .lower() 可以理解为一个匿名函数;

  

其功能类似于:

        def有趣(x)   返回(x [0], [1] .lower ())      之前      

如果想要以字母作为第一排序规则,并且字母大小写不敏感,该怎么实现?
  

  

这就能要运用到之前所讲到的

  

在默认情况下分类和排序函数接收的参数是元组时,它将会先按元组的第一个元素进行排序再按第二个元素进行排序,再按第三个,第四个…依次排序。
  

  

再配合λ返回一个自定义元组;代码如下:

        data=https://www.yisu.com/zixun/[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))   #将x [1] .lower()作为返回元组里的第一个元素,按照排序的排序规律,就会先按字母排的序,再按数字排序了   结果=排序(数据、关键=λx: (x [1] .lower (), x [0]))   打印(数据)#结果为[(1 B), (1, ' '), (2, ' '), (0, ' B ') (0, ' '))   打印(结果)#结果为[(0,' '),(1,' '),(2,' '),(0,' B '), (B)]      之前      

4(扩展]以dict作为列表的元素

  

这个列表里的元素是dict形式,每个dict都存有姓名和升高现在想要以升高进行升序排列:

        data=https://www.yisu.com/zixun/[{“名称”:“张三”,“高”:175},{“名称”:“李四”、“高度”:165},{“名称”:“王五”、“高度”:185}]   #将x['高']最为返回元组的第个一元素=排序结果(数据、关键=λx: (x['高'],['名字']))   打印(数据)#结果为   打印(结果)   #数据结果:[{“名称”:“张三”,“高”:175},{“名称”:“李四”、“高度”:165},{“名称”:“王五”、“高度”:185}]   #结果结果:[{“名称”:“李四”、“高度”:165},{“名称”:“张三”,“高”:175},{“名称”:“王五”、“高度”:185}]      

Python3实现对列表按元组指定列进行排序的方法分析