Я пытаюсь сгруппироватьBy, а затем вычислить процентиль на фрейме данных pyspark.Я протестировал следующий фрагмент кода в соответствии с этим stackoverflow post :
from pyspark.sql.types import FloatType
import pyspark.sql.functions as func
import numpy as np
qt_udf = func.udf(lambda x,qt: float(np.percentile(x,qt)), FloatType())
df_out = df_in.groupBy('Id').agg(func.collect_list('value').alias('data'))\
.withColumn('median', qt_udf(func.col('data'),func.lit(0.5)).cast("string"))
df_out.show()
, но получил следующую ошибку:
Traceback (последний вызов был последним):> df_out.show () ....> return lambda * a: f (* a) AttributeError: у объекта 'module' нет атрибута 'процентиля'
Это из-за непостоянной версии (1.4.1), функция процентиля была добавлена из версии 1.5.Невозможно обновить numpy версию в краткосрочной перспективе.