Python实现EXCEL表格的排序功能示例


Posted in Python onJune 25, 2019

EXCEL的数值排序功能还是挺强大的,升序、降序,尤其自定义排序,能够对多个字段进行排序工作。

那么,在Python大法中,有没有这样强大的排序功能呢?答案是有的,而且本人觉得Python的排序功能,一点不比EXCEL的差。

同样,我们依然用到的是强大的pandas这个三方库。我们先将numpy和pandas导入进来:

Python实现EXCEL表格的排序功能示例

接着构造一个今天要用到的DataFrame,我们用字典的形式来构造。

Python实现EXCEL表格的排序功能示例

都是随意构造的,内容别较真。我们先来个简单点的热热身,按照身高的降序来排列一下。

Python实现EXCEL表格的排序功能示例

我们用到的是df.sort_values()这个函数。第一个参数为by,传入你要排序的列的标签名即可,后面的ascending参数指示排序方法为升序还是降序,True为升序,False为降序。由于存在相同的身高,pandas会自动的比较两个相同身高所对应的index,按照index的升序来排列。

假如我有这样一个需求:先按照身高降序排序,若存在相同的身高,则再按照武力来降序排序,可以做到吗?

当然可以,我们只需要在by参数里传入列标签组成的列表即可。

Python实现EXCEL表格的排序功能示例

通过这个例子我们可以看到,by参数不但可以传入字符串,还可以传入字符串组成的列表,来实现对多个列进行排序。

接着,我的要求再高一点。身高我依然需要降序,但是武力我需要升序,可以吗?

我们直接上结果:

Python实现EXCEL表格的排序功能示例

跟by参数类似,我们只需要在ascending参数中也传入布尔值组成的列表就可以了,意思就是告诉pandas,这两列我各自需要的排序方式,就跟后面ascending参数里指定的一样。因此,这两个参数的列表内的元素个数需要是一致的,否则就会报错了,因为没法一一对应。

关于sort_values这个强大的排序函数就介绍到这了。除了这些参数之外,它还有inplace、kind和na_position等参数来应对不同的排序需求。可以参考官网文档进行学习

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
推荐下python/ironpython:从入门到精通
Oct 02 Python
Python实现删除文件但保留指定文件
Jun 21 Python
Python实现简单多线程任务队列
Feb 27 Python
在CentOS上配置Nginx+Gunicorn+Python+Flask环境的教程
Jun 07 Python
Django实战之用户认证(用户登录与注销)
Jul 16 Python
对python多线程与global变量详解
Nov 09 Python
Python Excel处理库openpyxl使用详解
May 09 Python
python爬虫实现中英翻译词典
Jun 25 Python
python字符串下标与切片及使用方法
Feb 13 Python
解决Opencv+Python cv2.imshow闪退问题
Apr 24 Python
Python实现DBSCAN聚类算法并样例测试
Jun 22 Python
使用pandas生成/读取csv文件的方法实例
Jul 09 Python
python实现动态创建类的方法分析
Jun 25 #Python
python pandas写入excel文件的方法示例
Jun 25 #Python
python多线程http压力测试脚本
Jun 25 #Python
Pyqt5 基本界面组件之inputDialog的使用
Jun 25 #Python
对PyQt5的输入对话框使用(QInputDialog)详解
Jun 25 #Python
如何使用Python标准库进行性能测试
Jun 25 #Python
python绘制评估优化算法性能的测试函数
Jun 25 #Python
You might like
《五等分的花嫁》漫画完结!2020年10月第2期TV动画制作组换血!
2020/03/06 日漫
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
2010/12/29 PHP
详解php语言最牛掰的Laravel框架
2017/11/20 PHP
Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例
2020/04/04 PHP
用javascript getComputedStyle获取和设置style的原理
2008/10/10 Javascript
JQuery 表格操作(交替显示、拖动表格行、选择行等)
2009/07/29 Javascript
改变文件域的样式实现思路同时兼容ie、firefox
2013/10/23 Javascript
将HTML的左右尖括号等转义成实体形式的两种实现方式
2014/05/04 Javascript
js 动态修改css文件用到了cssRule
2014/08/20 Javascript
javascript实现查找数组中最大值方法汇总
2016/02/13 Javascript
bootstrap jquery dataTable 异步ajax刷新表格数据的实现方法
2017/02/10 Javascript
vue实现全选和反选功能
2017/08/31 Javascript
如何用JavaScript实现功能齐全的单链表详解
2019/02/11 Javascript
微信小程序 腾讯地图显示偏差问题解决
2019/07/27 Javascript
解决VueCil代理本地proxytable无效报错404的问题
2020/11/07 Javascript
深入了解Vue3模板编译原理
2020/11/19 Vue.js
原生JS运动实现轮播图
2021/01/02 Javascript
pyqt4教程之widget使用示例分享
2014/03/07 Python
tensorflow构建BP神经网络的方法
2018/03/12 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
Python实现简单的猜单词小游戏
2020/10/28 Python
CSS3利用text-shadow属性实现多种效果的文字样式展现方法
2016/08/25 HTML / CSS
世界上最好的旅行夹克:BauBax
2018/12/23 全球购物
智能钱包:Ekster
2019/11/21 全球购物
经典c++面试题二
2015/08/14 面试题
车辆维修工自我评价怎么写
2013/09/20 职场文书
自学考试自我鉴定范文
2013/09/26 职场文书
行政办公室岗位职责
2014/03/18 职场文书
建筑投标担保书
2014/05/20 职场文书
招商引资工作汇报材料
2014/10/28 职场文书
小学二年级班主任工作经验交流材料
2015/11/02 职场文书
详解MySQL连接挂死的原因
2021/05/18 MySQL
浅谈如何提高PHP代码质量之端到端集成测试
2021/05/28 PHP
PHP实现rar解压读取扩展包小结
2021/06/03 PHP
python库sklearn常用操作
2021/08/23 Python
python使用shell脚本创建kafka连接器
2022/04/29 Python