2016-04-21 13 views
5

Ecco i miei dati di inputLa fusione delle gamme datetime alla fine della giornata e l'inizio del giorno successivo

case class DateRange(sd:DateTime,ed:DateTime) 

val sd1 = DateTime.parse("2016-04-04T20:00:00.000Z") 
val ed1 = DateTime.parse("2016-04-04T23:59:59.999Z") 

val sd2 = DateTime.parse("2016-04-05T00:00:00.000Z") 
val ed2 = DateTime.parse("2016-04-05T05:00:00.000Z") 

val sd3 = DateTime.parse("2016-04-05T20:00:00.000Z") 
val ed3 = DateTime.parse("2016-04-05T23:59:59.999Z") 

val sd4 = DateTime.parse("2016-04-06T00:00:00.000Z") 
val ed4 = DateTime.parse("2016-04-06T05:00:00.000Z") 

val sd5 = DateTime.parse("2016-04-07T10:00:00.000Z") 
val ed5 = DateTime.parse("2016-04-07T15:00:00.000Z") 

val drList = List(DateRange(sd1,ed1),DateRange(sd2,ed2),DateRange(sd3,ed3),DateRange(sd4,ed4),DateRange(sd5,ed5)) 

L'output desiderato che sto cercando è

val res = List(DateRange(sd1,ed2),DateRange(sd3,ed4),DateRange(sd5,ed5)) 

Qui il ed1, ed3 è la fine della giornata e sd1, sd3 sono l'inizio del giorno per le rispettive date. Voglio unire questo tipo di intervalli come possiamo vedere nell'output desiderato sopra.

Ho provato il partizionamento come questo

val result = drList.partition(x => x.sd.isEqual(x.sd.withTimeAtStartOfDay()) || x.ed.isEqual(x.ed.withTime(LocalTime.parse("23:59:59"))))) 

Ma non ottenere come unire il risultato. Grazie in anticipo.

risposta

2

È possibile utilizzare zip per ottenere il risultato:

val res = if(drList.size < 2) 
      { 
       drList 
      } 
      else 
      { 
       drList zip drList.drop(1) map { 
       case (prevRes, nexRes) => 
       if (prevRes.ed.plusMillis(1) == nexRes.sd) prevRes.copy(ed = nexRes.ed) 
       else DateRange(sd1, sd1) 
      } 
      res.filter(x => x.sd != x.ed) 
      } 

Qui SD1 è alcun datetime avere a parte il resto e filtrarlo fuori all'ultimo.

Problemi correlati