Pandas之排序函数sort_values()的实现
技术  /  管理员 发布于 7年前   255
一、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 npimport pandas as pddf=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 col30 A 2 01 A 1 12 B 9 93 NaN 8 44 D 7 25 C 7 8
依据第一列排序,并将该列空值放在首位
#依据第一列排序,并将该列空值放在首位print(df.sort_values(by=['col1'],na_position='first'))>>> col1 col2 col33 NaN 8 40 A 2 01 A 1 12 B 9 95 C 7 84 D 7 2
依据第二、三列,数值降序排序
#依据第二、三列,数值降序排序print(df.sort_values(by=['col2','col3'],ascending=False))>>> col1 col2 col32 B 9 93 NaN 8 45 C 7 84 D 7 20 A 2 01 A 1 1
根据第一列中数值排序,按降序排列,并替换原数据
#根据第一列中数值排序,按降序排列,并替换原数据df.sort_values(by=['col1'],ascending=False,inplace=True, na_position='first')print(df)>>> col1 col2 col33 NaN 8 44 D 7 25 C 7 82 B 9 91 A 1 10 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 x30 1 4 31 2 3 22 2 2 43 3 1 1 x2 x3 x10 4 3 11 3 2 22 2 4 23 1 1 3
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号