pyspark не допускает определяемые пользователем объекты Class как типы столбцов Dataframe.Вместо этого нам нужно создать StructType
, который можно использовать аналогично классу / именованному кортежу в python.
Например:
from pyspark.sql.types import *
from pyspark.sql.functions import udf
from pyspark.sql import functions as F
# from pyspark.sql.functions import *
d = [{'ID': '1', 'pID': 1000, 'startTime': '2018.07.02T03:34:20', 'endTime': '2018.07.03T02:40:20'},
{'ID': '1', 'pID': 1000, 'startTime': '2018.07.02T03:45:20', 'endTime': '2018.07.03T02:50:20'},
{'ID': '2', 'pID': 2000, 'startTime': '2018.07.02T03:34:20', 'endTime': '2018.07.03T02:40:20'},
{'ID': '2', 'pID': 2000, 'startTime': '2018.07.02T03:45:20', 'endTime': '2018.07.03T02:50:20'}]
df = spark.createDataFrame(d)
# Dates = namedtuple("Dates", "startTime endTime")
schema = ArrayType(StructType([
StructField("startTime", StringType(), False),
StructField("endTime", StringType(), False)
]))
MergeAdjacentUsages = udf(lambda xs: xs, schema)
df1 = df.groupBy(['ID', 'pID']).agg(MergeAdjacentUsages(
F.collect_list(F.struct('startTime', 'endTime'))).alias("Times"))
df1.show(truncate=False)
+---+----+----------------------------------------------------------------------------------------+
|ID |pID |Times |
+---+----+----------------------------------------------------------------------------------------+
|2 |2000|[[2018.07.02T03:34:20, 2018.07.03T02:40:20], [2018.07.02T03:45:20, 2018.07.03T02:50:20]]|
|1 |1000|[[2018.07.02T03:34:20, 2018.07.03T02:40:20], [2018.07.02T03:45:20, 2018.07.03T02:50:20]]|
+---+----+----------------------------------------------------------------------------------------+
Надеюсь, это поможет!