按照id分组并根据优先级创建列(Pyspark)
创始人
2024-08-24 06:00:41
0

可以使用groupby和pivot方法来解决此问题。首先,我们需要使用groupby方法按照id列分组。然后,我们可以使用pivot方法并指定“priority”列来创建新列。最后,我们需要使用fillna方法来使用默认值填充缺失的单元格。

以下是用于解决此问题的示例代码:

from pyspark.sql.functions import *
from pyspark.sql import SparkSession

# 创建Spark会话
spark = SparkSession.builder.appName("groupby_pivot_demo").getOrCreate()
spark.conf.set("spark.sql.shuffle.partitions", "5")

# 创建示例数据
data = [("id1", "A", 1),
       ("id1", "B", 2),
       ("id1", "C", 3),
       ("id2", "A", 2),
       ("id2", "B", 1),
       ("id3", "A", 3)]

df = spark.createDataFrame(data, ["id", "priority", "value"])

# 按照id分组并创建新列
df_grouped = df.groupBy("id").pivot("priority").agg(first(col("value")))

# 填充缺失单元格
df_grouped = df_grouped.fillna(0)

df_grouped.show()

输出结果:

+---+---+---+---+
| id|  A|  B|  C|
+---+---+---+---+
|id2|  2|  1|  0|
|id1|  1|  2|  3|
|id3|  3|  0|  0|
+---+---+---+---+

相关内容

热门资讯

第五分钟妙计!wpk免费辅助(... 第五分钟妙计!wpk免费辅助(透视)竟然有辅助插件(哔哩哔哩)一、wpk免费辅助游戏安装教程牌型概率...
三分钟教材!智星菠萝有挂吗(透... 三分钟教材!智星菠萝有挂吗(透视)本来是有辅助安装(哔哩哔哩)1、下载好智星菠萝有挂吗正确养号方法之...
四分钟策略!wepoker正确... 四分钟策略!wepoker正确养号方法(透视)确实是有辅助辅助(哔哩哔哩)1、每一步都需要思考,不同...
七分钟烘培!哈糖大菠萝怎么挂(... 七分钟烘培!哈糖大菠萝怎么挂(透视)真是真的有辅助安装(哔哩哔哩)1、游戏颠覆性的策略玩法,独创攻略...
第6分钟指引!aapoker脚... 第6分钟指引!aapoker脚本怎么用(透视)原来是有辅助教程(哔哩哔哩)1、aapoker脚本怎么...
6分钟手筋!德州辅助工具到底怎... 6分钟手筋!德州辅助工具到底怎么样(透视)竟然是有辅助安装(哔哩哔哩)1、德州辅助工具到底怎么样公共...
第二分钟方案!wepoker辅... 第二分钟方案!wepoker辅助透视软件(透视)果然存在有辅助插件(哔哩哔哩)wepoker辅助透视...
四分钟操作!wepoker有没... 四分钟操作!wepoker有没有挂(透视)原来真的有辅助开挂(哔哩哔哩)1、wepoker有没有挂免...
第五分钟指南!hhpkoer辅... 第五分钟指南!hhpkoer辅助器视频(透视)原来真的是有辅助插件(哔哩哔哩)1、hhpkoer辅助...
第2分钟办法!wepoker模... 第2分钟办法!wepoker模拟器哪个(透视)好像真的有辅助脚本(哔哩哔哩)1、下载好wepoker...