博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python中的sort()
阅读量:4608 次
发布时间:2019-06-09

本文共 1230 字,大约阅读时间需要 4 分钟。

Python中的sort()方法用于数组排序,本文以实例形式对此加以详细说明:

一、基本形式

列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不可修改的。

1
2
3
x
=
[
4
,
6
,
2
,
1
,
7
,
9
]
x.sort()
print
x
# [1, 2, 4, 6, 7, 9]

如果需要一个排序好的副本,同时保持原有列表不变,怎么实现呢

1
2
3
4
5
x
=
[
4
,
6
,
2
,
1
,
7
,
9
]
y
=
x[ : ]
y.sort()
print
y
#[1, 2, 4, 6, 7, 9]
print
x
#[4, 6, 2, 1, 7, 9]

注意:y = x[:] 通过分片操作将列表x的元素全部拷贝给y,如果简单的把x赋值给y:y = x,y和x还是指向同一个列表,并没有产生新的副本。

另一种获取已排序的列表副本的方法是使用sorted函数:

1
2
3
4
x
=
[
4
,
6
,
2
,
1
,
7
,
9
]
y
=
sorted
(x)
print
y
#[1, 2, 4, 6, 7, 9]
print
x
#[4, 6, 2, 1, 7, 9]

sorted返回一个有序的副本,并且类型总是列表,如下:

1
print
sorted
(
'Python'
)
#['P', 'h', 'n', 'o', 't', 'y']

二、自定义比较函数

可以定义自己的比较函数,然后通过参数传递给sort方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
def
comp(x, y):
if
x < y:
return
1
elif
x > y:
return
-
1
else
:
return
0
 
nums
=
[
3
,
2
,
8
,
0
,
1
]
nums.sort(comp)
print
nums
# 降序排序[8, 3, 2, 1, 0]
nums.sort(
cmp
)
# 调用内建函数cmp ,升序排序
print
nums
# 降序排序[0, 1, 2, 3, 8]

三、可选参数

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

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

1
2
3
x
=
[
'mmm'
,
'mm'
,
'mm'
,
'm'
]
x.sort(key
=
len
)
print
x
# ['m', 'mm', 'mm', 'mmm']

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

1
2
3
y
=
[
3
,
2
,
8
,
0
,
1
]
y.sort(reverse
=
True
)
print
y
#[8, 3, 2, 1, 0]

转载于:https://www.cnblogs.com/dancesir/p/7878295.html

你可能感兴趣的文章
三月23日测试Fiddler
查看>>
20171013_数据库新环境后期操作
查看>>
poj 1654 && poj 1675
查看>>
运维派 企业面试题1 监控MySQL主从同步是否异常
查看>>
Docker 版本
查看>>
poj 1753 Flip Game
查看>>
在深信服实习是怎样的体验(研发测试岗)
查看>>
Linux免密码登陆
查看>>
SpringMVC中文件的上传(上传到服务器)和下载问题(二)--------下载
查看>>
Socket & TCP &HTTP
查看>>
osip及eXosip的编译方法
查看>>
Hibernate composite key
查看>>
[CF Round #294 div2] D. A and B and Interesting Substrings 【Map】
查看>>
sed指令的奇淫技巧
查看>>
Spring异步执行(@Async)2点注意事项
查看>>
一个Web报表项目的性能分析和优化实践(七):性能监测工具JavaMelody
查看>>
寻找第K小的数。
查看>>
SpringBoot-(8)-配置MySQL数据库链接,配置数据坚挺拦截,创建默认数据表
查看>>
在Linux(ubuntu server)上面安装NodeJS的正确姿势
查看>>
【转】react的高阶组件
查看>>