首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >结合2行2 1,每2行2行

结合2行2 1,每2行2行
EN

Stack Overflow用户
提问于 2017-08-12 17:41:42
回答 1查看 810关注 0票数 1

我这里有一张火花放电数据,就像下面的图片。我想每两行进行一次分组,但在某种程度上:

  • 第一行将是第1行和第2行的用户,
  • 第二行将来自第2和第3行等。

就像这样:

代码语言:javascript
运行
复制
---CustomerID--previous_stockcodes----stock_codes-----

不使用价格和数量,前一篮子和现有篮子放在一起。例如,CustomerID 12347的第一行是:

代码语言:javascript
运行
复制
12347----[85116, 22375, 71...]-----[84625A, 84625C, ...]

我已经编写了循环来完成这个任务,但是这样做的效率很低,而且速度很慢。我想知道我是否能高效地使用火花放电来做一些事情,但我很难弄清楚。提前谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-13 08:54:27

您可以通过使用spark提供的lead函数获得下一行。

lead是一个窗口函数。

语法:lead(**column_name**,**int_value**,**default_value**) over ( column_name按column_name顺序进行分区)

int_value从当前行获取要引导的行数。

当找不到前导行时,default_value接受输入

代码语言:javascript
运行
复制
>>> input_df.show()
+----------+---------+----------------+
|customerID|invoiceNo|  stockCode_list|
+----------+---------+----------------+
|     12347|   537626|  [85116, 22375]|
|     12347|   542237|[84625A, 84625C]|
|     12347|   549222|  [22376, 22374]|
|     12347|   556201|  [23084, 23162]|
|     12348|   539318|  [84992, 22951]|
|     12348|   541998|  [21980, 21985]|
|     12348|   548955|  [23077, 23078]|
+----------+---------+----------------+

>>> from pyspark.sql.window import Window
>>> from pyspark.sql.functions import lead,col

>>> win_func = Window.partitionBy("customerID").orderBy("invoiceNo")
>>> new_col = lead("stockCode_list",1,None).over(win_func)
>>> req_df = input_df.select(col("customerID"),col("invoiceNo"),col("stockCode_list"),new_col.alias("req_col"))
>>> req_df.orderBy("customerID","invoiceNo").show()
+----------+---------+----------------+----------------+
|customerID|invoiceNo|  stockCode_list|         req_col|
+----------+---------+----------------+----------------+
|     12347|   537626|  [85116, 22375]|[84625A, 84625C]|
|     12347|   542237|[84625A, 84625C]|  [22376, 22374]|
|     12347|   549222|  [22376, 22374]|  [23084, 23162]|
|     12347|   556201|  [23084, 23162]|            null|
|     12348|   539318|  [84992, 22951]|  [21980, 21985]|
|     12348|   541998|  [21980, 21985]|  [23077, 23078]|
|     12348|   548955|  [23077, 23078]|            null|
+----------+---------+----------------+----------------+
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45653152

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档