【发布时间】:2016-05-16 18:56:05
【问题描述】:
我已经在 Spark 中使用 Window 成功创建了一个row_number()partitionBy,但我想通过降序而不是默认的升序对其进行排序。这是我的工作代码:
from pyspark import HiveContext
from pyspark.sql.types import *
from pyspark.sql import Row, functions as F
from pyspark.sql.window import Window
data_cooccur.select("driver", "also_item", "unit_count",
F.rowNumber().over(Window.partitionBy("driver").orderBy("unit_count")).alias("rowNum")).show()
这给了我这个结果:
+------+---------+----------+------+
|driver|also_item|unit_count|rowNum|
+------+---------+----------+------+
| s10| s11| 1| 1|
| s10| s13| 1| 2|
| s10| s17| 1| 3|
在这里我将 desc() 添加到降序排列:
data_cooccur.select("driver", "also_item", "unit_count", F.rowNumber().over(Window.partitionBy("driver").orderBy("unit_count").desc()).alias("rowNum")).show()
并得到这个错误:
AttributeError: 'WindowSpec' 对象没有属性 'desc'
我在这里做错了什么?
【问题讨论】:
-
在我的 PySpark (2.2.0) 上,我必须使用
row_number而不是rowNumber。
标签: python apache-spark pyspark apache-spark-sql window-functions