Pandas之排序函数sort_values()的实现


Posted in Python onJuly 09, 2019

一、sort_values()函数用途

pandas中的sort_values()函数原理类似于SQL中的order by,可以将数据集依照某个字段中的数据进行排序,该函数即可根据指定列数据也可根据指定行的数据排序。

二、sort_values()函数的具体参数

用法:

DataFrame.sort_values(by=‘##',axis=0,ascending=True, inplace=False, na_position=‘last')

参数说明

参数 说明
by 指定列名(axis=0或'index')或索引值(axis=1或'columns')
axis 若axis=0或'index',则按照指定列中数据大小排序;若axis=1或'columns',则按照指定索引中数据大小排序,默认axis=0
ascending 是否按指定列的数组升序排列,默认为True,即升序排列
inplace 是否用排序后的数据集替换原来的数据,默认为False,即不替换
na_position {‘first',‘last'},设定缺失值的显示位置

三、sort_values用法举例

创建数据框

#利用字典dict创建数据框
import numpy as np
import pandas as pd
df=pd.DataFrame({'col1':['A','A','B',np.nan,'D','C'],
         'col2':[2,1,9,8,7,7],
         'col3':[0,1,9,4,2,8]
})
print(df)

>>>
 col1 col2 col3
0  A   2   0
1  A   1   1
2  B   9   9
3 NaN   8   4
4  D   7   2
5  C   7   8

依据第一列排序,并将该列空值放在首位

#依据第一列排序,并将该列空值放在首位
print(df.sort_values(by=['col1'],na_position='first'))
>>>
 col1 col2 col3
3 NaN   8   4
0  A   2   0
1  A   1   1
2  B   9   9
5  C   7   8
4  D   7   2

依据第二、三列,数值降序排序

#依据第二、三列,数值降序排序
print(df.sort_values(by=['col2','col3'],ascending=False))
>>>
 col1 col2 col3
2  B   9   9
3 NaN   8   4
5  C   7   8
4  D   7   2
0  A   2   0
1  A   1   1

根据第一列中数值排序,按降序排列,并替换原数据

#根据第一列中数值排序,按降序排列,并替换原数据
df.sort_values(by=['col1'],ascending=False,inplace=True,
           na_position='first')
print(df)
>>>
 col1 col2 col3
3 NaN   8   4
4  D   7   2
5  C   7   8
2  B   9   9
1  A   1   1
0  A   2   0

按照索引值为0的行,即第一行的值来降序排序

x = pd.DataFrame({'x1':[1,2,2,3],'x2':[4,3,2,1],'x3':[3,2,4,1]}) 
print(x)
#按照索引值为0的行,即第一行的值来降序排序
print(x.sort_values(by =0,ascending=False,axis=1))
>>>
  x1 x2 x3
0  1  4  3
1  2  3  2
2  2  2  4
3  3  1  1
  x2 x3 x1
0  4  3  1
1  3  2  2
2  2  4  2
3  1  1  3

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

Python 相关文章推荐
python创建和使用字典实例详解
Nov 01 Python
python中__call__方法示例分析
Oct 11 Python
python爬虫实战之爬取京东商城实例教程
Apr 24 Python
Python+树莓派+YOLO打造一款人工智能照相机
Jan 02 Python
详解用python自制微信机器人,定时发送天气预报
Mar 25 Python
python tkinter基本属性详解
Sep 16 Python
Python读取YAML文件过程详解
Dec 30 Python
tensorflow之变量初始化(tf.Variable)使用详解
Feb 06 Python
Python3中的f-Strings增强版字符串格式化方法
Mar 04 Python
python怎么自定义捕获错误
Jun 29 Python
python 下载文件的几种方式分享
Apr 07 Python
python使用openpyxl库读写Excel表格的方法(增删改查操作)
May 02 Python
python爬虫之快速对js内容进行破解
Jul 09 #Python
python 求某条线上特定x值或y值的点坐标方法
Jul 09 #Python
python将字符串转换成json的方法小结
Jul 09 #Python
Python绘制堆叠柱状图的实例
Jul 09 #Python
python3 线性回归验证方法
Jul 09 #Python
python time.sleep()是睡眠线程还是进程
Jul 09 #Python
python logging模块的使用总结
Jul 09 #Python
You might like
php获取url参数方法总结
2014/11/13 PHP
php正则判断是否为合法身份证号的方法
2017/03/16 PHP
php删除一个路径下的所有文件夹和文件的方法
2018/02/07 PHP
详解php用static方法的原因
2018/09/12 PHP
javascript中的prototype属性实例分析说明
2010/08/09 Javascript
JavaScript的类型简单说明
2010/09/03 Javascript
javascript获取当前日期时间及其它操作函数
2011/01/11 Javascript
Jquery带搜索框的下拉菜单
2013/05/06 Javascript
JavaScript中instanceof运算符的用法总结
2013/11/19 Javascript
js中opener与parent的区别详细解析
2014/01/14 Javascript
jQuery如何将选中的对象转化为原始的DOM对象
2014/06/09 Javascript
javascript对中文按照拼音排序代码
2014/08/20 Javascript
Javascript实现商品秒杀倒计时(时间与服务器时间同步)
2015/09/16 Javascript
AngularJS 路由和模板实例及路由地址简化方法(必看)
2016/06/24 Javascript
JavaScript实现经典排序算法之插入排序
2016/12/28 Javascript
浅谈javascript中的事件冒泡和事件捕获
2016/12/28 Javascript
解决VUEX刷新的时候出现数据消失
2017/07/03 Javascript
vue实现图片上传功能
2020/05/28 Javascript
Node 使用express-http-proxy 做api网关的实现
2020/10/15 Javascript
python写的一个文本编辑器
2014/01/23 Python
Python中一些自然语言工具的使用的入门教程
2015/04/13 Python
Python中的条件判断语句基础学习教程
2016/02/07 Python
python django框架中使用FastDFS分布式文件系统的安装方法
2019/06/10 Python
set在python里的含义和用法
2019/06/24 Python
python print出共轭复数的方法详解
2019/06/25 Python
Pytorch DataLoader 变长数据处理方式
2020/01/08 Python
Python Django2 model 查询介绍(条件、范围、模糊查询)
2020/03/16 Python
行政部总经理岗位职责
2014/01/04 职场文书
万年牢教学反思
2014/02/15 职场文书
教师节活动主持词
2014/04/02 职场文书
小学生操行评语大全
2014/04/22 职场文书
学校百日安全生产活动总结
2014/07/05 职场文书
中学教师暑期培训方案
2014/08/27 职场文书
党支部承诺书
2015/01/20 职场文书
同学聚会祝酒词
2015/08/10 职场文书
Win11 KB5015814遇安装失败 影响开始菜单性能解决方法
2022/07/15 数码科技