【已解决】如何获取到DF数据里最新的调薪时间,就是薪资最高且时间最早?

news2024/9/23 5:34:32
问题说明:


前几天在Python最强王者交流群【群除我佬】问了一个Pandas处理的问题,这里拿出来给大家分享下。

看上去不太好理解,其实说白了,就是在工资最高里,再找时间最早的。

换句话说就是,这三个人,每个人找工资最高,然后在这个范围里找时间最早  就是他的调薪时间。

解决方法:

这里我们提供一种解决方案:

import pandas as pd

data = {'name': ['陈六', '吴三', '吴三', '陈六', '钱十', '陈六', '吴五', '吴五', '陈六', '吴八', '钱十', '陈六'],
        'date': ['2024-01-04', '2024-01-13', '2024-01-29', '2024-01-12', '2024-01-20', '2024-01-19', '2024-01-27',
                 '2024-01-20', '2024-01-09', '2024-01-08', '2024-01-14', '2024-01-28'],
        'salary': [6026, 5352, 5791, 9567, 9728, 6160, 9015, 9508, 9253, 9570, 8690, 7395]}

df = pd.DataFrame(data)
print(df.sort_values(['name', 'salary', 'date'], ascending=[True, False, True]).groupby(['name']).head(1))
结果展示:

代码说明:
print(df.sort_values(['name', 'salary', 'date'], ascending=[True, False, True])
  • 排序 DataFrame:
    • df.sort_values([...]): 对 DataFrame df 进行排序。
    • ['name', 'salary', 'date']: 表示按 namesalary 和 date 三列进行排序。
    • ascending=[True, False, True]:
      • 对 name 列进行升序排列(即 A 到 Z)。
      • 对 salary 列进行降序排列(即从高到低)。
      • 对 date 列进行升序排列(即从早到晚)。

经过这一步,DataFrame 将首先按姓名升序排列,在同一姓名下,按薪资降序排列;如果薪资相同,则按日期升序排列。

.groupby(['name']).head(1)
  • 分组并选取第一条记录:
    • .groupby(['name']): 根据 name 列将 DataFrame 分组,这会将具有相同名字的行聚集在一起。
    • .head(1): 从每个分组中提取前一行。由于之前已经按薪资降序排列,因此每个姓名组的第一行将是该姓名下薪资最高的记录。

  • 打印结果: 最终代码会输出一个 DataFrame,其中每个员工姓名只会保留薪资最高的一条记录,若有多个相同薪资,则选择日期最早的记录。
概要总结:
  • 这段代码的主要目的是从 DataFrame 中提取每个员工薪资最高且在先的记录。
  • 首先按姓名和薪资进行排序,然后分组并获取每个员工的最高薪资记录。

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

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

相关文章

益九未来CEO曾宪军:创新引领,打造智能售货机行业新标杆

在智能零售行业迅速发展的今天,益九未来(天津)科技发展有限公司正以其创新精神和前瞻性的战略布局,引领着智能售货机市场的潮流。而这一切的背后,离不开总经理(CEO)曾宪军先生的卓越领导和远见卓…

人类预期寿命数据-1960至2022年(世界各国与中国各省)

数据简介:人类预期寿命是指在特定年龄出生的人群,按照当前的死亡率水平,预期平均能够存活的年数。预期寿命衡量一个国家和地区卫生健康状况、社会经济发展水平和生活条件的重要参数,这次数据包含世界各国(1960-2022年&…

代理IP类型详细解析:那么多种协议的代理如何选?

代理IP已经成为跨境业务的得力工具,但是仍有许多新手小白在初次接触到代理IP服务商时,不知道具体如何选择代理IP类型,面对五花八门的代理类型名称,往往需要付出一定的试错成本才知道哪个适合自己的业务。今天就来给大家科普科普&a…

深度学习中的规范化-层规范化

文章目录 层规范化层规范化参数与公式normalized_shape传入一个整数接口函数LayerNorm计算手动计算 normalized_shape传入一个列表接口函数LayerNorm计算手动计算 层规范化 在批量规范化这篇文章里详细介绍了批量规范化在卷积神经网络里的使用,本篇文章将继续介绍另…

LVS中NAT模式和DR模式实战讲解

1DR模式 DR:Direct Routing,直接路由,LVS默认模式,应用最广泛,通过为请求报文重新封装一个MAC首部进行 转发,源MAC是DIP所在的接口的MAC,目标MAC是某挑选出的RS的RIP所在接口的MAC地址;源 IP/PORT&#xf…

C++:auto关键字、内联函数、引用、带默认形参值的函数、函数重载

一、auto关键字 在C中,auto关键字是一个类型说明符,用于自动类型推导。 使用 auto 关键字时,变量的类型 是在编译时由编译器 根据 初始化表达式 自动推导出来的。这意味着你 不能在 声明 auto 变量时 不进行初始化 声明 auto 变量时&#x…

“八股文”:是助力还是阻力?

在程序员面试中,“八股文”是一个绕不开的话题。所谓“八股文”,指的是那些在面试中经常出现的标准问题及其答案,例如“解释一下死锁的概念”、“CAP理论是什么”等。这些内容通常被求职者反复练习,以至于变成了某种固定的模式或套…

分享6类10种政务AI大模型应用场景

大模型是指具有大规模参数和复杂计算结构的机器学习模型。这些模型通常由深度神经网络构建而成,拥有数十亿甚至数千亿个参数。大模型的设计目的是提高模型的表达能力和预测性能,能够处理更加复杂的任务和数据。大模型在各种领域都有广泛的应用&#xff0…

adword — Recho | pwn题目记录

涉及到以前没接触过的点,记录下。 checksec: IDA: 很明显的一个栈溢出,但是一直有一个while循环,就算劫持控制流后也出不了这个循环。这里学到了一个新方法: pwntools的shutdown(send) def shutdown(…

C++现代教程四

float转string不带多余0 float a 1.2; std::tostring(a); // 1.200000 std::ostringstream strStream; strStream << a; // 1.2 if (!strStream.view().empty()) // 判定流有数据// 边框融合 float measureText(std::u8string text, FontTypes::Rectangle &recta…

Marin说PCB之1000-BASE-T1上的共模电感的选型知多少---02

今天刚刚好是立秋的第一天&#xff0c;天气还是有点炎热的。不知道诸位老铁们有没有买今年秋天的第一杯奶茶&#xff0c;反正小编我是下班到家吃饭的时候买了一杯伯牙绝弦&#xff0c;喝起来味道还是不错的&#xff0c;而且奶茶店里今天几乎爆满&#xff0c;我足足等了30分钟才…

计算机网络面试-核心概念-问题理解

目录 1.计算机网络OSI协议七层结构功能分别是什么&#xff1f;如何理解这些功能 2.物理层、数据链路层、网络层、传输层和应用层&#xff0c;这五个层之间功能的关系&#xff0c;或者说是否存在协调关系 3. 数据链路层功能理解 4.MAC地址和以太网协议 5.以太网协议中的CSMA…

第十八节、野猪撞墙判定和等候计时

一、野猪撞墙修改 1、判断地面 2、检测半径迁移至头部 3、设置前后的监测点 二、自动调整检测半径 玩家的检测半径实现自动调整 bounds 是正常世界窗口的碰触体外框 这一章节很复杂观看代码physicalcheck和enemy

IT治理体系:构建企业数字化转型的基石

随着信息技术的飞速发展&#xff0c;企业数字化转型已成为不可逆转的趋势。在这一进程中&#xff0c;IT治理体系作为指导、控制和监督信息技术资源使用与管理的框架&#xff0c;其重要性日益凸显。它不仅关乎企业信息系统的稳定运行&#xff0c;更是推动业务创新、提升竞争力、…

计算机毕业设计选题推荐-基于网页开发和数据抓取技术的在线新闻聚合平台-Java/Python项目实战

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

从源码剖析Java线程池的工作机制

文章目录 从源码剖析Java线程池的工作机制一、序言二、基础概念1、线程调度模型2、线程池创建方式&#xff08;1&#xff09;Executors工具类&#xff08;2&#xff09;ThreadPoolExecutor构造方法2.1 核心参数2.3 拒绝策略实现 三、源码剖析1、状态控制变量ctl2、线程执行exec…

MindSearch:AI 时代的“思考型”搜索引擎

随着AI技术的飞速发展&#xff0c;搜索引擎领域也迎来了新的变革。继 OpenAI 发布 SearchGPT 之后&#xff0c;国内也涌现出一批优秀的AI搜索引擎&#xff0c;其中&#xff0c;由中科大和上海人工智能实验室联合研发的 MindSearch&#xff08;思索&#xff09;尤为引人注目。这…

php收银系统源码-线上下单,门店接单

1.收银系统开发语言 核心开发语言: PHP、HTML5、Dart后台接口: PHP7.3后合管理网站: HTML5vue2.0element-uicssjs线下收银台&#xff08;安卓/PC收银、安卓自助收银&#xff09;: Dart3框架&#xff1a;Flutter 3.19.6助手: uniapp商城: uniapp 2.线上商城下单&#xff0c;门…

theaterjs使用

import theaterJS from "theaterjs"; interface ITheaterOptions {autoplay?: boolean;minSpeed?: {type: number;erase: number;};maxSpeed?: {type: number;erase: number;}; } export default function useTheater(id: string, options: ITheaterOptions, addS…