脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - python数据分析之DateFrame数据排序和排名方式

python数据分析之DateFrame数据排序和排名方式

2022-12-29 12:07柳小葱 Python

这篇文章主要介绍了python数据分析之DateFrame数据排序和排名方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

1.数据排序

DataFrame.sort_values(by,axis=0,ascending=True,inplace=False,kind="quicksort",na_position="last",ignore_index=False)
"""
by:要排序的名称列表
axis:轴,0表示行,1表示列
ascending:升序或者降序排列,默认是True,升序
inplace:是否直接在数据上修改,True为直接修改df,False为副本
kind:指定排序算法,
na_position:空值(NaN)的位置,值为first空值在数据开头,值为last空值在数据最后。
ignore_index:布尔值,是否忽略索引,值为True标记索引(从0开始顺序的整数值),False则忽略索引
"""

 

2.按某列降序排序

import pandas as pd
exelFile="C:\\Users\\Administrator\\Desktop\\python数据分析Code\\Code\\03\\46\\mrbook.xlsx"
df=pd.DataFrame(pd.read_excel(exelFile))
pd.set_option('display.max_rows',1000)#设置展示最高行数
pd.set_option('display.max_columns',1000)#设置展示最高列数
pd.set_option('display.unicode.east_asian_width',True)
pd.set_option("display.unicode.ambiguous_as_wide",True)
#按“销量”列降序排序
df1=df.sort_values(by="销量",ascending=False)
print(df1)

结果如图所示:

python数据分析之DateFrame数据排序和排名方式

 

3.按多列升降序排列

#先按照图书名称降序排列,再按照销量降序排列
df2=df.sort_values(by=["图书名称","销量"])

python数据分析之DateFrame数据排序和排名方式

 

4.对统计结构排序

将类别分组并统计总销量降序排列。

df3=df.groupby(["类别"])["销量"].sum().reset_index()
df4=df3.sort_values(by="销量",ascending=False)
print(df4)

结构如下:

python数据分析之DateFrame数据排序和排名方式

 

5.数据排名

DataFrame.rank(axis-0,method="average",numeric_only=None,na_option="keep",ascending=True,,pct=False)
"""
axis:轴,0表示行,1表示列
method:表示在相同值的情况下所使用的排序方法,参数如下:average:默认值,平均值排名;min:最小值排名;max:最大值排名;first:按第一次出现的顺序排列;dense:密集排序,类似于最小值排序,,但排名每次只增加1,相同排名的数据只只占据一个名词。
numeric_only:对于DataFrame,如果设置值为True,并只对数字列进行排序。
ascending:升序或者降序排列,默认值为True
pct:布尔值,是否以百分比形式返回排名,默认值为False
"""

实例:

对销量相同的产品,按照顺序排名的平均值进行平均排名

#先排序
df=df.sort_values(by="销量",ascending=False)
#按照顺序排名的平均值进行平均排名
df["顺序排名"]=df["销量"].rank(ascending=False)

这里两个数销量相同,分别为3和4名,取平均值为3.5

python数据分析之DateFrame数据排序和排名方式

对销量相同的产品,按照在原表中出现的顺序进行排名

#先排序
df=df.sort_values(by="销量",ascending=False)
df["顺序排名"]=df["销量"].rank(method="first",ascending=False)

结果如下:很正常的结果

python数据分析之DateFrame数据排序和排名方式

对销量相同的产品,按照顺序排名并取最小值最为排名

#先排序
df=df.sort_values(by="销量",ascending=False)
df["顺序排名"]=df["销量"].rank(method="min",ascending=False)

排名如下:相同数量的都按照最小排名填写

python数据分析之DateFrame数据排序和排名方式

对销量相同的产品,按照顺序排名并取最大值最为排名

#先排序
df=df.sort_values(by="销量",ascending=False)
df["顺序排名"]=df["销量"].rank(method="max",ascending=False)

排名如下:相同数量的都按照最大排名填写

python数据分析之DateFrame数据排序和排名方式

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://liuxiaocong.blog.csdn.net/article/details/115053352

延伸 · 阅读

精彩推荐
  • Pythonpython正则表达式面试题解答

    python正则表达式面试题解答

    这篇文章主要为大家分析了python正则表达式常见面试题,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    wangbowj1234602021-01-08
  • Pythonpython 存储json数据的操作

    python 存储json数据的操作

    这篇文章主要介绍了python 存储json数据的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    秋殇阁5082021-10-26
  • PythonTensorFlow人工智能学习按索引取数据及维度变换详解

    TensorFlow人工智能学习按索引取数据及维度变换详解

    这篇文章主要为大家介绍了TensorFlow人工智能学习按索引取数据及维度变换的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助...

    Swayzzu11302022-02-27
  • Python使用python把Excel中的数据在页面中可视化

    使用python把Excel中的数据在页面中可视化

    最近学习数据分析,感觉Python做数据分析真的好用,下面这篇文章主要给大家介绍了关于如何使用python把Excel中的数据在页面中可视化的相关资料,需要的朋友...

    小皮猪4052022-11-15
  • PythonPython使用matplotlib创建Gif动图的思路

    Python使用matplotlib创建Gif动图的思路

    这篇文章主要介绍了Python使用matplotlib创建Gif动图,我们将讨论matplotlib提供的名为“Animation”的动画库之一,Python二维绘图库是Matplolib可以轻松创建绘图、直...

    bashendixie55302022-12-07
  • PythonPython使用shelve模块实现简单数据存储的方法

    Python使用shelve模块实现简单数据存储的方法

    这篇文章主要介绍了Python使用shelve模块实现简单数据存储的方法,涉及shelve模块实现数据存储的技巧,需要的朋友可以参考下...

    Gavin_dinggengjia6082020-07-03
  • Pythonpython导入csv文件出现SyntaxError问题分析

    python导入csv文件出现SyntaxError问题分析

    这篇文章主要介绍了python导入csv文件出现SyntaxError问题分析,同时涉及python导入csv文件的三种方法,具有一定借鉴价值,需要的朋友可以参考下。...

    我的前进日志4812020-12-25
  • PythonPython numpy 点数组去重的实例

    Python numpy 点数组去重的实例

    下面小编就为大家分享一篇Python numpy 点数组去重的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    CUG_Bear6342021-02-01