Python中数据的排序
目录
列表的排序
列表的排序可以使用列表自带的 sort() 方法,也可以使用 sorted() 函数
sort() 方法是修改原列表;而 sorted() 函数是对列表的复制再排序,返回一个新的列表,两者有区别。

sort(key,reverse)方法
对于列表中的元素是数字的话,默认是按照大小排序
>>a=[3,1,6,2,-4,7]
>>a.sort() //从小到大
>>print(a)
[-4, 1, 2, 3, 6, 7]
>>a.sort(reverse=Ture) //倒序,从大到小
>>print(a)
[7, 6, 3, 2, 1, -4]
还可以传入参数 key,key参数是对要排序的数据的操作
>>a.sort(key=lambda x:abs(x))
>>print(a)
[1, 2, 3, -4, 6, 7]
对于列表中元素是字符串的话,默认是按照 元素第一个字母的ASCII 值来排序
>>a=['day','Back','alice','Change']
>>a.sort() //默认是安装第一个字母的ASCII值排序
>>print(a)
['Back', 'Change', 'alice', 'day']
>>a.sort(key=str.lower) //不区分第一个字母的大小写排序
>>print(a)
['alice', 'Back', 'Change', 'day']
sorted(target,key,reverse) 函数
对于列表中的元素是数字的话,默认是按照大小排序
>>a=[3,1,6,2,-4,7]
>>b=sorted(a)
>>print(b)
[-4, 1, 2, 3, 6, 7] //从小到大
>>c=sorted(a,reverse=True)
[7, 6, 3, 2, 1, -4] //倒序,从大到小
>>d=sorted(a,key=lambda x:abs(x))
[1, 2, 3, -4, 6, 7]
对于列表中元素是字符串的话,默认是按照 元素第一个字母的ASCII 值来排序
>>a=['day','Back','alice','Change']
>>b=sorted(a) //默认是安装第一个字母的ASCII值排序
>>print(b)
['Back', 'Change', 'alice', 'day']
>>c=sorted(a,key=str.lower) //不区分第一个字母的大小写排序
>>print(c)
['alice', 'Back', 'Change', 'day']
元组tuple的排序
sort(key,reverse)方法
元组自身没有 sort() 排序方法,要对元组用 sort() 进行排序,我们可以先将元组转换成list 列表,然后排序,最后再转换成元组。
>>a=(3,1,6,2,-4,7)
>>b=list(a)
>>b.sort() //也可以传入key和reverse参数
>>a=tuple(b)
>>print(a)
(-4, 1, 2, 3, 6, 7)
sorted(target,key,reverse)函数
>>a=(3,1,6,2,-4,7)
>>b=sorted(a) //也可以传入key和reverse参数
>>print(b)
[-4, 1, 2, 3, 6, 7]
字符串的排序
python中的字符串类型是不允许直接修改元素的。必须先把要排序的字符串放在容器里,如 list 。然后再利用 list 的 sort() 方法排序
>>a="hello,word!"
>>b=list(a)
>>b.sort()
>>print(b)
['!', ',', 'd', 'e', 'h', 'l', 'l', 'o', 'o', 'r', 'w']
>>c="".join(b)
>>print(c)
!,dehlloorw
或者直接一行搞定
>>a="hello,word!"
>>s="".join((lambda x:(x.sort(),x)[1])(list(s)))
>>print(s)
!,dehlloorw
或者利用 sorted() 函数
>>a="hello,word!"
>>b=sorted(a)
>>print(b,type(b))
['!', ',', 'd', 'e', 'h', 'l', 'l', 'o', 'o', 'r', 'w'] <class 'list'>
>>c="".join(b)
>>print(c)
!,dehlloorw
字典的排序
对字典进行排序?这其实是一个伪命题,搞清楚python字典的定义---字典本身默认以key的字符顺序输出显示---就像我们用的真实的字典一样,按照abcd字母的顺序排列,并且本质上各自没有先后关系,是一个哈希表的结构:
但实际应用中我们确实有这种排序的“需求”-----安装key值首字母的ASCII值排序,按照values的值排序,或者按照别的奇怪的顺序进行输出,我们只需要把字典转化成 lis t或者 tuple,把字典每一对键值转化为list中的两位子list或者子tuple再输出,就可以达到我们的目的
import operator
stu={'name':'xie','age':"20",'id':"40",'sex':'man'}
##安装key值升序进行排列
a=dict(sorted(stu.items(),key=operator.itemgetter(0),reverse=False))
##安装key值降序进行排列
b=dict(sorted(stu.items(),key=operator.itemgetter(0),reverse=True))
##安装value值升序进行排列
c=dict(sorted(stu.items(),key=operator.itemgetter(1),reverse=False))
##安装value键值降序进行排列
d=dict(sorted(stu.items(),key=operator.itemgetter(1),reverse=True))
print(stu)
print(a)
print(b)
print(c)
print(d)
##############################################################
{'name': 'xie', 'age': '20', 'id': '40', 'sex': 'man'}
{'age': '20', 'id': '40', 'name': 'xie', 'sex': 'man'}
{'sex': 'man', 'name': 'xie', 'id': '40', 'age': '20'}
{'age': '20', 'id': '40', 'sex': 'man', 'name': 'xie'}
{'name': 'xie', 'sex': 'man', 'id': '40', 'age': '20'}
Python中数据的排序的更多相关文章
- Python中对列表排序实例
Python中对列表排序实例 发布时间:2015-01-04 09:01:50 投稿:junjie 这篇文章主要介绍了Python中对列表排序实例,本文给出了9个List的排序实例,需要的朋友可以参考 ...
- Python中的字典排序
我想将 b = {'a':234,'b':1,'c':2,'e':2387} 分别按照key和value进行排序,该怎样办呢? Python中比较常用的排序有两个函数, 一.定义 (1)一个是List ...
- 漫谈python中的搜索/排序
在数据结构那一块,搜索有顺序查找/二分查找/hash查找,而排序有冒泡排序/选择排序/插入排序/归并排序/快速排序.如果遇到数据量和数组排列方式不同,基于时间复杂度的考虑,可能需要用到混合算法.如果用 ...
- Python中数据的保存和读取
在科学计算的过程中,往往需要保存一些数据,也经常需要把保存的这些数据加载到程序中,在 Matlab 中我们可以用 save 和 lood 函数很方便的实现.类似的在 Python 中,我们可以用 nu ...
- Python中的选择排序
选择排序 选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理如下.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大 ...
- python中数据类型转换
python中list和str互转 1.list转str 假设有一个名为test_list的list,转换后的str名为test_str 则转换方法: test_str = "" ...
- python中的列表排序
对列表进行排序是常见的操作,最简单的方式是使用sort()函数. 1.一般用法 不管列表元素是数.字符串还是元组,函数sort()总是就地操作列表,按升序进行排列元素,并返回None. #数 > ...
- Python 中数据的序列化和反序列化(json处理)
概念: JSON(JavaScript Object Notation):是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Programming ...
- python中数据的保存
1.将list中的数据写入到excel文件中 利用python包numpy(实现方式应该有许多种,这里只是记录成功实现的一种)中的savetxt 局限性:要保存的list可以为[1,2,3,4,5]这 ...
随机推荐
- 第01章-Java SE8的流库
从迭代到流的操作 流表面上看起来和集合很类似,都可以让我们转换和获取数据,但是它们之间存在着显著的差异 流并不存储其元素,这些元素可能存储在底层的集合中,或者是按需生成的 流的操作不会修改其数据源 流 ...
- Java I/O流 04
I/O流·其他流 序列流 * A:什么是序列流 * 序列流可以把多个字节输入流整合成一个,从序列流中读取数据时,将从被整合的第一个流开始,读完后再读下一个 * B:使用方式 * 整合两个:Sequen ...
- Idea 报错 xxxx too long
问题:写单元测试,debug时,报错如下图 解决方法1: 在项目/.idea/workspace.xml文件中添加一行代码如下 <component name="PropertiesC ...
- Java Swing 自定义Dialog确认对话框
Java Swing 自定义Dialog 需求:当点击JFrame窗口的关闭按钮时,弹框询问是否确定关闭窗口,如果是则关闭程序,否就让弹框消失什么也不做(使用Dialog). 分析:虽然Java提供了 ...
- 【Git】敏感信息保护
保护Git仓库敏感信息 代码中无可避免有一些敏感信息,包含但不限于,数据库信息,密钥,账号信息等等.通常我们会把这些信息放在配置文件,这些信息若泄露会造成安全问题. 以前我们做法,是把配置文件通过.g ...
- CentOS7.8搭建STF
安装命令插件(rz.sz): yum install -y lrzsz wget unzip zip编辑配置文件导致命令无法使用时:export PATH=/usr/local/sbin:/usr/l ...
- 攻防世界 reverse easy_Maze
easy_Maze 从题目可得知是简单的迷宫问题 int __cdecl main(int argc, const char **argv, const char **envp) { __int64 ...
- effective解读-第一条 静态工厂创建对象代替构造器
好处 有名称,能见名知意.例如BigInteger的probablePrime方法 享元模式.单例模式中使用 享元模式:创建对象代价很高,重复调用已有对象,例如数据库连接等.享元模式是单例模式的一个拓 ...
- 软件漏洞--Hello-Shellcode
软件漏洞--Hello-Shellcode 使用上一次的栈溢出的漏洞软件 可以直接通过栈溢出来修改返回值,或者要跳转的函数地址 实现一个ShellCode来跳转自己的代码 源bug软件代码 #defi ...
- 依赖反转原则DIP 与使用了Repository模式的asp.net core项目结构
DIP 依赖反转原则 Dependency Inversion Principle 的定义如下: 高级别的模块不应该依赖于低级别的模块, 他们都应该依赖于抽象. 假设Controller依赖于Repo ...