I’ve successfully create a row_number()
partitionBy
by in Spark using Window, but would like to sort this by descending, instead of the default ascending. Here is my working code:
JavaScript
x
8
1
from pyspark import HiveContext
2
from pyspark.sql.types import *
3
from pyspark.sql import Row, functions as F
4
from pyspark.sql.window import Window
5
6
data_cooccur.select("driver", "also_item", "unit_count",
7
F.rowNumber().over(Window.partitionBy("driver").orderBy("unit_count")).alias("rowNum")).show()
8
That gives me this result:
JavaScript
1
7
1
+------+---------+----------+------+
2
|driver|also_item|unit_count|rowNum|
3
+------+---------+----------+------+
4
| s10| s11| 1| 1|
5
| s10| s13| 1| 2|
6
| s10| s17| 1| 3|
7
And here I add the desc() to order descending:
JavaScript
1
2
1
data_cooccur.select("driver", "also_item", "unit_count", F.rowNumber().over(Window.partitionBy("driver").orderBy("unit_count").desc()).alias("rowNum")).show()
2
And get this error:
AttributeError: ‘WindowSpec’ object has no attribute ‘desc’
What am I doing wrong here?
Advertisement
Answer
desc
should be applied on a column not a window definition. You can use either a method on a column:
JavaScript
1
7
1
from pyspark.sql.functions import col, row_number
2
from pyspark.sql.window import Window
3
4
F.row_number().over(
5
Window.partitionBy("driver").orderBy(col("unit_count").desc())
6
)
7
or a standalone function:
JavaScript
1
7
1
from pyspark.sql.functions import desc
2
from pyspark.sql.window import Window
3
4
F.row_number().over(
5
Window.partitionBy("driver").orderBy(desc("unit_count"))
6
)
7