【发布时间】:2019-11-24 16:20:13
【问题描述】:
全部,
我有一个数据集,其定义如下:
eno|date|attendance
1|01-Jan-2010|P
1|02-Jan-2010|P
1|03-Jan-2010|A
1|04-Jan-2010|P
1|05-Jan-2010|P
2|01-Jan-2010|P
2|02-Jan-2010|P
2|03-Jan-2010|P
2|04-Jan-2010|A
2|05-Jan-2010|P
对于每个员工,要求是创建一个“间隔组”,基本上按时间顺序对出勤值进行分组。组是将相似的出勤值组合在一起直到看到新的出勤值的东西。所以预期的输出是:
eno|date|attendance|attendanceGroup
1|01-Jan-2010|P|1
1|02-Jan-2010|P|1
1|03-Jan-2010|A|2
1|04-Jan-2010|P|3
1|05-Jan-2010|P|3
2|01-Jan-2010|P|1
2|02-Jan-2010|P|1
2|03-Jan-2010|P|1
2|04-Jan-2010|A|2
2|05-Jan-2010|P|3
到目前为止,我所能做的就是获取上一行的出勤值,但完全不知道如何从这里开始......提前非常感谢......
from datetime import datetime, timedelta
EmployeeAttendance = Row("eno", "date", "attendance")
EmpAttRowList = [EmployeeAttendance("1", datetime.now().date() - timedelta(days=100), "Y"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=99), "Y"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=98), "N"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=97), "Y"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=96), "Y"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=95), "N"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=94), "Y"),
EmployeeAttendance("1", datetime.now().date() - timedelta(days=93), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=100), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=99), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=98), "N"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=97), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=96), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=95), "N"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=94), "N"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=93), "N"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=92), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=91), "Y"),
EmployeeAttendance("2", datetime.now().date() - timedelta(days=90), "N"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=97), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=96), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=95), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=94), "N"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=93), "N"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=92), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=91), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=90), "Y"),
EmployeeAttendance("3", datetime.now().date() - timedelta(days=89), "Y")
]
df = spark.createDataFrame(EmpAttRowList, EmployeeAttendance)
window = Window.partitionBy(df['eno']).orderBy("date")
previousrowattendance = lag(df["attendance"]).over(window)
【问题讨论】: