Pandas 数据处理-排序与排名的深度探索【第69篇—python:文本数据处理】

news2025/1/12 12:08:38

文章目录

  • Pandas 数据处理-排序与排名的深度探索
    • 1. sort_index方法
    • 2. sort_values方法
    • 3. rank方法
    • 4. 多列排序
    • 5. 排名方法的参数详解
    • 6. 处理重复值
    • 7. 对索引进行排名
    • 8. 多级索引排序与排名
    • 9. 更高级的排序自定义
    • 10. 性能优化技巧
      • 10.1 使用`nsmallest`和`nlargest`
      • 10.2 使用`sort_values`的`inplace`参数
      • 10.3 使用`merge`进行排名
  • 总结

Pandas 数据处理-排序与排名的深度探索

Pandas是Python中广泛使用的数据处理库,提供了丰富的功能来处理和分析数据。在数据分析过程中,经常需要对数据进行排序和排名,以便更好地理解和分析数据。本文将介绍Pandas中常用的排序、排名方法,包括sort_indexsort_valuesrank,并通过代码实例和解析来演示它们的使用。

image-20240208150118873

1. sort_index方法

sort_index方法主要用于按照索引进行排序。默认情况下,它会按照索引的升序进行排序,但也可以通过参数指定降序排列。下面是一个简单的例子:

import pandas as pd

# 创建一个DataFrame
data = {'Name': ['Alice', 'Bob', 'Charlie', 'David'],
        'Age': [25, 30, 22, 35],
        'Score': [85, 90, 75, 95]}

df = pd.DataFrame(data, index=[3, 1, 4, 2])

# 使用sort_index进行升序排序
df_sorted = df.sort_index()
print("按照索引升序排序:\n", df_sorted)

# 使用sort_index进行降序排序
df_sorted_desc = df.sort_index(ascending=False)
print("按照索引降序排序:\n", df_sorted_desc)

在上面的例子中,sort_index方法根据索引进行了升序和降序排序。

image-20240208150134866

2. sort_values方法

sort_values方法用于按照指定列的值进行排序。可以通过by参数指定排序的列,也可以通过ascending参数指定升序或降序。以下是一个示例:

# 使用sort_values按照Age列的值进行升序排序
df_age_sorted = df.sort_values(by='Age')
print("按照Age列升序排序:\n", df_age_sorted)

# 使用sort_values按照Score列的值进行降序排序
df_score_sorted_desc = df.sort_values(by='Score', ascending=False)
print("按照Score列降序排序:\n", df_score_sorted_desc)

在上面的例子中,sort_values方法分别根据"Age"列进行升序排序和根据"Score"列进行降序排序。

image-20240208150151961

3. rank方法

rank方法用于为数据分配排名。默认情况下,它根据数值大小进行排名,具有相同数值的元素将分配相同的排名,且排名取平均值。以下是一个例子:

# 使用rank方法为Age列分配排名
df['Age_Rank'] = df['Age'].rank()
print("根据Age列分配排名:\n", df)

在上面的例子中,rank方法为"Age"列分配了排名,并将结果添加到DataFrame中的新列"Age_Rank"中。

通过以上代码实例,我们展示了Pandas中常用的排序、排名方法。这些方法在数据分析和处理中起着重要作用,帮助我们更好地理解和利用数据。阅读本文后,你应该能够灵活运用这些方法来满足不同数据处理的需求。

4. 多列排序

在实际数据分析中,经常需要根据多列的值进行排序。Pandas中,可以通过传递包含多个列名的列表来实现多列排序。以下是一个例子:

# 使用sort_values按照Score列升序、Age列降序排序
df_multi_sorted = df.sort_values(by=['Score', 'Age'], ascending=[True, False])
print("按照Score列升序、Age列降序排序:\n", df_multi_sorted)

在上述例子中,sort_values方法根据"Score"列进行升序排序,然后在"Score"列相同的情况下,根据"Age"列进行降序排序。

5. 排名方法的参数详解

rank方法具有一些可选参数,可以根据实际需求进行调整。以下是一些常用的参数:

  • method: 指定处理相同值时的方法,默认为"average",表示取平均值。其他可选值包括"min"、“max”、"first"和"dense"等。
  • ascending: 指定排名的升序或降序,默认为True(升序)。
  • na_option: 指定对缺失值的处理方式,默认为"keep",表示保留缺失值;可以设置为"top"或"bottom",表示将缺失值分别排在最前或最后。
# 使用rank方法,设置method和na_option参数
df['Score_Rank'] = df['Score'].rank(method='min', ascending=False, na_option='top')
print("根据Score列分配排名,使用min方法和top参数:\n", df)

在上面的例子中,rank方法使用了"min"方法,即相同值取最小排名,同时将缺失值排在最前。

通过这些参数的合理运用,我们可以更灵活地控制排名方法的行为,以适应不同的数据情况。

6. 处理重复值

在数据集中,可能存在重复的行,而sort_values方法也可以用于处理重复值。通过duplicateskeep参数,我们可以灵活地选择如何处理重复的行。

# 创建含有重复值的DataFrame
data_with_duplicates = {'Name': ['Alice', 'Bob', 'Charlie', 'David', 'Alice'],
                        'Age': [25, 30, 22, 35, 25],
                        'Score': [85, 90, 75, 95, 85]}

df_duplicates = pd.DataFrame(data_with_duplicates)

# 使用sort_values处理重复值
df_no_duplicates = df_duplicates.sort_values(by=['Name', 'Age'], keep='first')
print("处理重复值后的DataFrame:\n", df_no_duplicates)

在上述例子中,sort_values方法根据"Name"列和"Age"列排序,并通过keep='first'保留第一次出现的重复行,删除后续的重复行。

7. 对索引进行排名

除了对列进行排序和排名,Pandas也支持对索引进行排序和排名。这对于处理时间序列数据等场景非常有用。

# 对索引进行排序
df_index_sorted = df.sort_index(ascending=False)
print("对索引降序排序:\n", df_index_sorted)

# 使用rank方法为索引分配排名
df['Index_Rank'] = df.index.rank()
print("对索引进行排名:\n", df)

在上述例子中,sort_index方法用于对索引进行排序,而rank方法则用于为索引分配排名。

8. 多级索引排序与排名

Pandas支持多级索引,这在处理复杂层次化数据时非常有用。我们可以使用sort_index方法对多级索引进行排序,以及使用rank方法进行排名。

# 创建具有多级索引的DataFrame
index_data = [('Group1', 'A'), ('Group1', 'B'), ('Group2', 'A'), ('Group2', 'B')]
multi_index = pd.MultiIndex.from_tuples(index_data, names=['Group', 'Subgroup'])

data_multi_index = {'Age': [25, 30, 22, 35],
                   'Score': [85, 90, 75, 95]}

df_multi_index = pd.DataFrame(data_multi_index, index=multi_index)

# 对多级索引进行排序
df_multi_sorted = df_multi_index.sort_index(level=['Group', 'Subgroup'], ascending=[True, False])
print("对多级索引排序:\n", df_multi_sorted)

# 使用rank方法为多级索引分配排名
df_multi_index['Rank'] = df_multi_index.groupby('Group')['Score'].rank(ascending=False)
print("对多级索引进行排名:\n", df_multi_index)

在上述例子中,sort_index方法根据多级索引中"Group"和"Subgroup"的层级进行排序,而rank方法使用groupby对多级索引的"Group"进行分组,然后为每组内的"Score"列进行排名。

image-20240208150232126

9. 更高级的排序自定义

有时,我们可能需要更高级的排序自定义,例如根据自定义函数或条件进行排序。在这种情况下,可以使用key参数。

# 创建一个DataFrame
data_custom_sort = {'Name': ['Alice', 'Bob', 'Charlie', 'David'],
                    'Age': [25, 30, 22, 35],
                    'Score': [85, 90, 75, 95]}

df_custom_sort = pd.DataFrame(data_custom_sort)

# 使用sort_values自定义排序规则
df_custom_sorted = df_custom_sort.sort_values(by='Age', key=lambda x: x % 2)
print("根据Age列进行奇偶排序:\n", df_custom_sorted)

在上述例子中,sort_values方法通过key参数,根据"Age"列的奇偶性进行排序。

10. 性能优化技巧

在处理大规模数据集时,性能优化变得尤为重要。在Pandas中,一些技巧可以帮助提高排序和排名的执行效率。

10.1 使用nsmallestnlargest

如果只需要获取最小或最大的几行数据,可以使用nsmallestnlargest方法,它们比完整的排序更高效。

# 使用nsmallest获取Age列最小的两行数据
df_nsmallest = df.nsmallest(2, 'Age')
print("Age列最小的两行数据:\n", df_nsmallest)

10.2 使用sort_valuesinplace参数

当对数据进行排序时,可以使用inplace=True参数来直接修改原始DataFrame,而不是创建一个新的排序后的副本。

# 使用sort_values对Score列进行升序排序,直接修改原始DataFrame
df.sort_values(by='Score', inplace=True)
print("原始DataFrame经过Score列升序排序:\n", df)

10.3 使用merge进行排名

对于需要根据其他列的值进行排名的情况,可以使用merge方法结合rank来提高性能。

# 创建一个DataFrame用于排名
rank_df = pd.DataFrame({'Name': ['Alice', 'Bob', 'Charlie', 'David'],
                        'Rank_Score': [4, 3, 2, 1]})

# 使用merge将排名合并到原始DataFrame
df_merged = pd.merge(df, rank_df, on='Name')
print("将排名合并到原始DataFrame:\n", df_merged)

通过这些性能优化技巧,可以在处理大规模数据时更加高效地进行排序和排名操作,提升代码执行速度。

image-20240208150257753

总结

在本篇技术博客中,我们深入研究了Pandas中的排序和排名方法,包括sort_indexsort_valuesrank。通过具体的代码实例和解析,我们详细介绍了这些方法的使用方式,使读者能够更好地理解和应用于实际的数据处理场景。

首先,我们学习了如何使用sort_index方法按照索引对数据进行排序,以及如何控制升序和降序排列。接着,我们探讨了sort_values方法,演示了根据单列或多列的值进行排序的方式,并介绍了处理重复值的方法。在排名方面,我们通过rank方法展示了如何为数据分配排名,以及如何通过一些参数调整排名的行为。

进一步地,我们介绍了多级索引的排序与排名,展示了对复杂层次化数据的处理方法。此外,我们讨论了一些高级排序自定义的技巧,包括使用自定义函数进行排序。

在性能优化方面,我们提出了几种有效的技巧,例如使用nsmallestnlargest方法、sort_valuesinplace参数,以及通过merge方法进行排名。这些技巧有助于在处理大规模数据集时提高代码的执行效率。

总体而言,通过本文的学习,读者应该能够更灵活地运用Pandas中的排序和排名方法,从而在实际的数据分析工作中取得更好的效果。这些技能对于数据科学家、分析师和工程师来说都是非常宝贵的,能够帮助他们更高效、更准确地处理和分析数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1440339.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

io三个练习:

练习一: 使用 四种方式拷贝文件,并统计各自用时 1字节流的基本流:一次读写一个字节 2字节流的基本流:一次读写一个字节数组 3字节缓冲流:一次读写一个字节 4字节缓冲流:一次读写一个字节数组 public clas…

TCP的连接和断开详解

目录 1.TCP基础知识 1.1.TCP 头格式 1.2.TCP协议介绍 1.3.UDP协议介绍 1.4.TCP 和 UDP 区别 1.5.TCP 和 UDP 应用场景 1.6.计算机网络相关术语(缩写) 2.TCP 连接建立:三次握手 2.1.TCP 三次握手过程 2.2.三次握手原理 2.3.异常分析…

JavaScript 入门 完整版

目录 第一个知识点:引入js文件 内部引用: 外部引用: 第二个知识点:javascript的基本语法 定义变量: 条件控制(if - else if - else) 第三个知识点:javascript里的数据类型、运算符: 数字类型 字符串类型 布尔…

【蓝桥杯单片机记录】IO基础与LED控制

目录 一、IO基础 1.1 IAP15F2K61S2芯片原理图 1.2不同工作模式 二、新建工程的一些补充 2.1 keil中没有IAP15F2K61S2的头文件 解决:在isp软件中找到如下​编辑 2.2keil中的芯片选择 2.3推荐字体 三、sbit关键字 四、LED控制 4.1原理图 4.2不能直接通过IO…

【深度学习:掌握监督学习】掌握监督学习综合指南

【深度学习:掌握监督学习】掌握监督学习综合指南 监督学习的定义和简要说明监督学习在人工智能中的重要性和相关性概述什么是监督学习?基本概念主要组件:输入要素和目标标签 训练监督式学习模型监督学习算法的类型分类回归每个类别中的流行算…

洞察 Electric Capital 2023 年开发者报告,找准未来 Web3 开发趋势

作者:Electric Capital 编译:TinTinLand 原文链接:https://www.developerreport.com/developer-report 近期,Electric Capital 发布了 2023 年年度加密开发者报告,对 818k 开源存储库中的 4.85 亿次代码提交进行分析…

C#上位机与三菱PLC的通信04--MC协议之A-1E报文测试

到目前为止,还没有网上有哪个文章有我如此的报文分析,操作实例,一大批都是抄来抄去,没有截图,没有说明,没有实例,有卵用呀,仅以此文章献给最爱的粉丝,希望对各位大师有些…

vue教程-介绍与使用

vue介绍 介绍 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。 安装 最简单的例子就是,创建一个htm…

2024年【广东省安全员B证第四批(项目负责人)】考试及广东省安全员B证第四批(项目负责人)考试题

题库来源:安全生产模拟考试一点通公众号小程序 广东省安全员B证第四批(项目负责人)考试考前必练!安全生产模拟考试一点通每个月更新广东省安全员B证第四批(项目负责人)考试题题目及答案!多做几…

代码随想录算法训练营第二十五天 |216.组合总和III,17.电话号码的字母组合(已补充)

剪枝操作讲解:(已观看) 带你学透回溯算法-组合问题的剪枝操作(对应力扣题目:77.组合)| 回溯法精讲!_哔哩哔哩_bilibili 216.组合总和III(已观看) 1、题目链接&#xf…

文件上传-Webshell

Webshell简介 webshell就是以aspphpjsp或者cgi等网页文件形式存在的一种命令执行环境,也可以将其称做为一种网页木马后门。 攻击者可通过这种网页后门获得网站服务器操作权限,控制网站服务器以进行上传下载文件、查看数据库、执行命令等… 什么是木马 …

设计模式2-对象池模式

对象池模式,Object Pool Pattern,当你的应用程序需要频繁创建和销毁某种资源(比如数据库连接、线程、socket连接等)时,Object Pool 设计模式就变得很有用。它通过预先创建一组对象并将它们保存在池中,以便在…

压敏电阻简介

压敏电阻 原理 压敏电阻器是一种具有瞬态电压抑制功能的元件,可以用来代替瞬态抑制二极管、齐纳二极管和电容器的组合。压敏电阻器可以对IC及其它设备的电路进行保护,防止因静电放电、浪涌及其它瞬态电流(如雷击等)而造成对它们…

什么是GitOps

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版,欢迎购买。点击进入详情 GitOps 改变了软件和基础设施的管理方式,以 Git 作为管理和自动化应用程序和基础设施整个生命周期的中心枢纽。 它建立在版本控制、协作以及持续集成和…

axios get 请求 url 转码 空格转成+,导致请求失败(前端解决)

问题 GET 请求参数: URL-encoded 后: 浏览器将空格转成了,导致服务报错,返回 400。 解决 在请求拦截器中,对 params 进行处理。 axios.interceptors.request.use((config) > {let url config.url;if (config…

k8s-项目部署案例

一、容器交付流程 在k8s平台部署项目流程 在K8s部署Java网站项目 DockerFile 如果是http访问,需要在镜像仓库配置可信任IP 三、使用工作负载控制器部署镜像 建议至少配置两个标签 一个是声明项目类型的 一个是项目名称的 继续配置属性 资源配额 健康检查 五、使…

elk之search API

写在前面 本文看下查询相关内容,这也是我们在实际工作中接触的最多的,所以有必要好好学习下! 1:查询的分类 主要分为如下2类: 1:基于get查询参数的URI search 2:基于post body的request body search&am…

机器学习1一knn算法

1.基础知识点介绍 曼哈顿距离一般是比欧式距离长的除非在一维空间 拐弯的就是曼哈顿距离 Knn查看前5行数据head(),info看空非空 查看特征对应的类型 Head()默认前5行,head(3)就是前3行数据 Unique()可以查看分类后的结果 csv的…

《学成在线》微服务实战项目实操笔记系列(P1~P83)【上】

史上最详细《学成在线》项目实操笔记系列【上】,跟视频的每一P对应,全系列12万字,涵盖详细步骤与问题的解决方案。如果你操作到某一步卡壳,参考这篇,相信会带给你极大启发。 一、前期准备 1.1 项目介绍 P2 To C面向…

Leecode之随机链表的复制

一.题目及剖析 https://leetcode.cn/problems/copy-list-with-random-pointer/ 这个题目的意思就是拷贝一份复杂链表,难点在于它的random指针所指向的空间与拷贝下来的链表之间缺少一种联系,当然可以用遍历链表的方式通过value去找那块空间,不过时间复杂度太高. 二.思路引入 …