-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtermin.py
60 lines (51 loc) · 2 KB
/
termin.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
from icalendar import Calendar
import pytz
class Termin(object):
#keys = ('DTSTAMP', 'DESCRIPTION', 'URL', 'SUMMARY', 'LOCATION', 'DTSTART', 'GEO', 'CLASS', 'CATEGORIES', 'UID')
keys = ('DTSTAMP', 'DESCRIPTION', 'URL', 'SUMMARY', 'LOCATION', 'DTSTART', 'CLASS', 'CATEGORIES', 'UID')
@staticmethod
def from_entry(entry):
"""
baut aus einem iCalender eintrag ein Termin Objekt
"""
termin = Termin()
for key in Termin.keys:
if key in entry:
termin.value[key] = entry.decoded(key)
return termin
def __init__(self):
self.value = {}
def get(self, name):
return self.value[name]
def get_local_start_time(self):
"""
x.get_local_start_time() -> datum
Gibt start Zeitpunkt des begines von Termin x in lokaler Zeit zurueck
datum ist ein Objekt.
"""
datum = self.value["DTSTART"]
# wenn keine Zeitzone angeben ist, nehme UTC an
if not datum.tzinfo:
src_zone = pytz.timezone("Europe/Berlin")
datum = src_zone.localize(datum)
# und jetzt umwandeln
dst_zone = pytz.timezone("Europe/Berlin")
return datum.astimezone(dst_zone)
def __str__(self):
datum = self.get_local_start_time().strftime("%Y-%m-%d %H:%M")
if "DESCRIPTION" in self.value:
return "%s: %s - %s" % (datum, self.value["SUMMARY"], self.value["DESCRIPTION"])
return "%s: %s" % (datum, self.value["SUMMARY"])
def load_from_str(data):
"""
load_from_str(data) -> list
Konvertiert eine gelesene iCalender Datei in eine nach Datum sortierte Liste von Termin Objekten.
data is String
list is a list from Termin objects
"""
cal = Calendar.from_ical(data)
# aus dem ical eine Liste von Termin Objekten bauen
liste = [Termin.from_entry(entry) for entry in cal.subcomponents]
# liste nach Datum sortieren
liste.sort(key=lambda datum: datum.get("DTSTART").timetuple())
return liste