”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何按多列升序和降序对 Pandas DataFrame 进行排序?

如何按多列升序和降序对 Pandas DataFrame 进行排序?

发布于2024-12-22
浏览:646

How to Sort a Pandas DataFrame by Multiple Columns in Ascending and Descending Order?

按多列对 Pandas Dataframe 进行排序

按多列对 Pandas Dataframe 进行排序是数据分析中的常见操作。考虑一个包含“a”、“b”和“c”列的数据框。要按“b”列升序和“c”列降序对此数据框进行排序,请按照下列步骤操作:

从 Pandas 版本 0.17.0 开始,排序方法已被弃用,转而使用 sort_values。从版本 0.20.0 开始,排序已被完全删除。但是,参数和结果保持不变:

df.sort_values(['a', 'b'], ascending=[True, False])

使用已弃用的排序的等效方法方法是:

df.sort(['a', 'b'], ascending=[True, False])

例如,考虑一个数据帧 df1,其列“a”和“b”中具有随机整数值:

import pandas as pd
import numpy as np

df1 = pd.DataFrame(np.random.randint(1, 5, (10, 2)), columns=['a', 'b'])

按 'a' 升序排序此数据帧order 和 'b' 按降序排列给出:

df1.sort(['a', 'b'], ascending=[True, False])
   a  b
2  1  4
7  1  3
1  1  2
3  1  2
4  3  2
6  4  4
0  4  3
9  4  3
5  4  1
8  4  1

请记住,默认情况下排序方法不是就地排序。要使用排序值更新 df1,请将排序方法的结果分配给 df1 或在方法调用中使用 inplace=True:

df1 = df1.sort(['a', 'b'], ascending=[True, False])

df1.sort(['a', 'b'], ascending=[True, False], inplace=True)
最新教程 更多>
  • 如何在Java字符串中正确地将单反斜杠替换为双反斜杠?
    如何在Java字符串中正确地将单反斜杠替换为双反斜杠?
    在字符串中用双反斜杠替换单反斜杠当尝试使用replaceAll将像“\something\”这样的字符串转换为“\”时某事”,开发人员经常遇到错误。使用 ReplaceAll("\", "\\") 方法的常见方法会导致异常“java.util.regex.Pa...
    编程 发布于2024-12-22
  • 尽管在 Eclipse 的查找和替换中工作,为什么我的 Java Regex 电子邮件验证失败?
    尽管在 Eclipse 的查找和替换中工作,为什么我的 Java Regex 电子邮件验证失败?
    Java 正则表达式电子邮件验证出现问题在尝试使用正则表达式验证电子邮件地址时,Java 用户遇到了以下问题:即使对于格式正确的电子邮件地址,验证也会失败。尽管事实上,当在 Eclipse 中的“查找和替换”功能中使用正则表达式时,该正则表达式会匹配电子邮件地址,但在与 Java 的 Pattern...
    编程 发布于2024-12-22
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-12-22
  • 为什么在将 std::min/max 与 #define NOMINMAX 一起使用时会出现错误?
    为什么在将 std::min/max 与 #define NOMINMAX 一起使用时会出现错误?
    使用 std::min/max 和 #define NOMINMAX在 main.cpp 文件的最近更新中,您引入了以下预处理器指令: #define NOMINMAX #include <Windows.h> #include <algorithm>此操作允许您在代码中使用...
    编程 发布于2024-12-22
  • JHat 如何帮助识别和调试 Java 内存泄漏?
    JHat 如何帮助识别和调试 Java 内存泄漏?
    使用 JHat 识别 Java 中的内存泄漏在 Java 中查找内存泄漏可能具有挑战性,但是 JHat(JDK 中包含的一个工具)提供有关堆使用情况的宝贵见解。虽然 JHat 提供了堆分配的基本视图,但查明内存泄漏的根本原因可能很困难。本文提供了一种系统方法来识别大型对象树并定位导致内存泄漏的潜在引...
    编程 发布于2024-12-22
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-22
  • 使用 Python 的“w+”文件模式有什么含义?
    使用 Python 的“w+”文件模式有什么含义?
    Python 文件模式的混乱 "w 在 Python 中,有许多文件模式允许您以不同的方式与文件交互'w ' 就是这样一种模式,它引起了一些混乱,让我们澄清一下它的用法:理解文件。模式根据Python文档,“w”模式打开一个文件以进行写入和更新。此外,该模式中的“w”表示该...
    编程 发布于2024-12-22
  • Java 的内置功能如何可靠地验证电子邮件地址?
    Java 的内置功能如何可靠地验证电子邮件地址?
    探索 Java 中的电子邮件验证方法电子邮件地址的有效性在各种应用中至关重要。虽然 Apache Commons Validator 一直是 Java 电子邮件验证的流行选择,但开发人员经常寻求替代解决方案。本文深入研究了使用官方 Java 电子邮件包验证电子邮件地址的综合方法。isValidEma...
    编程 发布于2024-12-22
  • 掌握 JavaScript 中的对象
    掌握 JavaScript 中的对象
    JavaScript 中的对象 在 JavaScript 中,对象是键值对的集合,其中值可以是数据(属性)或函数(方法)。对象是 JavaScript 的基础,因为 JavaScript 中几乎所有内容都是对象,包括数组、函数,甚至其他对象。 1.创建对象 ...
    编程 发布于2024-12-22
  • C++ 中与运算符 (&) 的使用方式有哪些不同?
    C++ 中与运算符 (&) 的使用方式有哪些不同?
    && 在 C 语言中如何工作 理解 & 运算符& C 中的运算符有多种用途,包括:获取某个地址变量: &x 返回变量 x 的内存地址。通过引用传递参数: void foo(CDummy& x);通过引用将变量 x 传递给函数 foo,允许在 foo 内部所做的修改反映在原始变量中。声明引用变量: i...
    编程 发布于2024-12-22
  • 马尼拉 DevFest 推动创新、包容性和负责任的人工智能
    马尼拉 DevFest 推动创新、包容性和负责任的人工智能
    图片来自GDG Manila Facebook页面(https://m.facebook.com/story.php?story_fbid=pfbid02Xh4ED8NwUnfrh9wrDS2pJKhYbpya4QxCMFWcNCeKuCpg9LgkmQ96B85FUSqo5w7bl&id=6156...
    编程 发布于2024-12-22
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-12-22
  • C++中静态工厂方法和工厂类如何选择?
    C++中静态工厂方法和工厂类如何选择?
    如何在 C 中正确实现工厂方法模式 工厂方法模式是一种设计模式,允许创建对象而无需指定对象的确切类要创建的对象。当运行时确定要创建的对象的类时,或者需要提供统一的接口来创建不同类型的对象时,通常会使用这种模式。在 C 中,有以下几种方式实现工厂方法模式。一种常见的方法是使用在要为其创建对象的类中定义...
    编程 发布于2024-12-22
  • Java 中的 HashMap 或 Hashtable:对于单线程应用程序来说,哪个更高效?
    Java 中的 HashMap 或 Hashtable:对于单线程应用程序来说,哪个更高效?
    Java 中的 HashMap 与 Hashtable:非线程应用程序的主要区别和效率HashMap 和 Hashtable 是 Java 中的基本数据结构,它们存储键值对。了解它们的区别对于选择最合适的选项至关重要。主要区别:同步: Hashtable 是同步的,而 HashMap 是同步的不是。...
    编程 发布于2024-12-22
  • MySQL 能否处理遥远过去的日期,例如 1200 年?
    MySQL 能否处理遥远过去的日期,例如 1200 年?
    MySQL 对历史日期的支持许多数据库系统,包括 MySQL,在处理历史日期时都有局限性。本文探讨了存储和使用公历之前的日期的限制和替代方案。MySQL 可以处理像 1200 这样的日期吗?从技术上讲,MySQL 可以存储日期早在 1000 年。然而,对于在此之前的日期,存在潜在的问题考虑。历史日期...
    编程 发布于2024-12-22

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3