pyspark window排序

文章介绍了在PySpark中,如何使用window函数进行数据排名,特别是rank、dense_rank和row_number三个函数的区别。rank函数在遇到并列名次时会占用下一个名次,dense_rank则不占用,而row_number不考虑并列情况,依次赋值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

from pyspark.sql.window import Window
from pyspark.sql.functions import rank, col

window = Window.partitionBy(df['xx1']).orderBy(df['socre'].desc())
aid_aidlist_df = df.select('*', rank().over(window).alias('rank')) \
    .filter(col('rank') <= 50) 

( 1 ) rank 函数:ranking 列的 5 位、5 位、5 位、8 位,也就是说,如果有并列名次的行,会占用下一名次的位置。例如,正常排名是:1、2、3、4,但是现在前 3 名是并列的名次,结果就是 1、1、1、4。

( 2 ) dense_rank 函数:dense_rank 列的 5 位、5 位、5 位、6 位,也就是说,如果有并列名次的行,不占用下一名次的位置。例如,正常排名是:1、2、3、4,但是现在前 3 名是并列的名次,结果就是 1、1、1、2。

( 3 ) row_number 函数:row_num 列的 5 位、6 位、7 位、8 位,也就是说,不考虑并列名次的情况。例如,前 3 名是并列的名次,排名结果就是正常的 1、2、3、4。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值