2016-06-25 6 views
6

Przeprowadziłem kilka testów. Tu jest mój kodu:Czy biblioteka DDay Ical prawidłowo oblicza powtarzające się reguły?

var systemTimeZone = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 
var icalTimeZone = iCalTimeZone.FromSystemTimeZone(systemTimeZone); 

var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 

var iCalendar = new iCalendar(); 
var pacificTimeZone = _iCalendar.AddTimeZone(icalTimeZone); 

var event = new Event 
{ 
    Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
    DTStart = new iCalDateTime(2015, 9, 8, 10, 30, 0, pacificTimeZone.TZID, iCalendar), 
    Duration = new TimeSpan(0, 1, 0, 0) 
}; 

var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 

event.RecurrenceRules.Add(rp); 
iCalendar.Events.Add(_event); 
var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 

oto wynik:

10 occurences - oto Period.StartTime.Value i UTC Właściwości wystąpień

Wartość - 9/8/2015 10:30:00 - UTC 9/8/2015 17:30:00
Wartość - 9/15/2015 10:30:00 - UTC 9/15/2015 17:30:00
Wartość - 22.09.2015 10:30:00 - UTC 9/22/2015 17:30:00
Wartość - 9/29/2015 10:30:00 - UTC 9/29/2015 17:30:00
Wartość - 06.10.2015 10:30:00 - UTC 06.10.2015 17: 30:00
Wartość - 10/13/2015 10:30:00 - UTC 10/13/2015 1 7:30:00
Wartość - 20.10.2015 10:30:00 - UTC 10/20/2015 17:30:00
Wartość - 27.10.2015 10:30: 00 - UTC 27.10.2015 17:30:00
Wartość -11/3/2015 10:30:00 - UTC 03.11.2015 17:30:00 (to powinno być 18:30:00!)
Wartość - 11/10/2015 10:30:00 - UTC 10.11.2015 17:30:00 (powinno to być 18:30:00!)

enter image description here

Jak widać, dwa ostatnie powinny mieć czas UTC 18:30 : 00. Zastanawiam się więc, czy tak działa DDay Ical, i nie powinienem liczyć na to, że otrzymam datetime UTC, albo jeśli robię coś nie tak.

+0

może to mieć coś wspólnego z letni? – Thorarins

Odpowiedz

8

Otrzymujesz tę różnicę czasu ze względu na oszczędność czasu letniego.Jednym z możliwych rozwiązań nie jest uzyskanie strefy czasowej wg nazwy Pacific Standard Time

// First load a file containing time zone information for Pacific Standard Time 
var systemTimeZone = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 

W miejsce tej strefy czasowej systemu wykorzystania takich jak

var systemTimeZone = TimeZoneInfo.GetSystemTimeZones().FirstOrDefault(); 

lub po prostu dodać lokalną strefę czasową:

iCalendar iCalendar= new iCalendar(); 
iCalendar.AddLocalTimeZone(); 

Aby znaleźć wszystkie zarejestrowane strefy czasowe, click here

ReadOnlyCollection<TimeZoneInfo> zones = TimeZoneInfo.GetSystemTimeZones(); 
Console.WriteLine("The local system has the following {0} time zones", zones.Count); 
foreach (TimeZoneInfo zone in zones) 
    Console.WriteLine(zone.Id); 

po prostu użyć GetSystemTimeZones() w kodzie jak

public static void Test1() 
    { 
     var systemTimeZone = TimeZoneInfo.GetSystemTimeZones().FirstOrDefault(); 
     //TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 
     var icalTimeZone = iCalTimeZone.FromSystemTimeZone(systemTimeZone); 

     var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
     var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 

     var iCalendar = new iCalendar(); 
     var pacificTimeZone = iCalendar.AddTimeZone(icalTimeZone); 

     var _event = 
     new Event 
     { 
      Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
      DTStart = new iCalDateTime(2015, 9, 8, 10, 30, 0, pacificTimeZone.TZID, iCalendar), 
      Duration = new TimeSpan(0, 1, 0, 0) 
     }; 

     var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 

     _event.RecurrenceRules.Add(rp); 
     iCalendar.Events.Add(_event); 

     var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 
    } 

kiedy debugowania to zajechało drogę wyjścia jak

stack

można zmienić strefę czasową odpowiednio i uzyskać wynik. Mam nadzieję, że ci to pomoże.

+0

Dzięki. Jestem świadomy problemu związanego z redukcją czasu letniego. Jak pokazuje moje pytanie, otrzymuję prawidłowe wartości PST - to UTC jest niepoprawne. Nie widzę, jak twoja odpowiedź rozwiązuje mój problem. – richard

+0

Jak sądzę, tak właśnie działa DDay Ical. –

+0

OK, więc odpowiedź brzmi nie, DDay Ical nie oblicza poprawnie wystąpień. Czy to jest poprawne? – richard

1

Don't use dday.ical; użyj ical.net.

To powinno Ci zacząć:

var iCalendar = new Calendar(); 

var start = new DateTime(2015, 9, 8, 10, 30, 0); 
var e = new Event 
{ 
    Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
    DtStart = new CalDateTime(start, "Pacific Standard Time"), 
    Duration = TimeSpan.FromHours(1) 
}; 

var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 
e.RecurrenceRules.Add(rp); 
iCalendar.Events.Add(e); 

var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 
var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 

Wyniki:

ical-net-recurrence-result

Powiązane problemy