-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathCB2.py
121 lines (89 loc) · 3.31 KB
/
CB2.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#!/usr/bin/env python
# coding: utf-8
# In[15]:
from icalendar import Calendar, Event
from urllib.request import urlopen
import urllib.request
import requests
from bs4 import BeautifulSoup
import ssl
from datetime import datetime
from sqlalchemy import create_engine, Column, String, Integer, MetaData
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
# In[16]:
#init connection to sqlite
engine = create_engine("sqlite:///events.db")
#create session to cache commands for sqlite engine instance
Session = sessionmaker(bind = engine)
session = Session()
#provide table definition
Base = declarative_base()
class Event(Base):
__tablename__ = 'event'
id = Column('id',Integer, primary_key = True)
district = Column(Integer)
title = Column(String(100))
date = Column(String(50))
details = Column(String(1000))
time = Column(String(50))
def __init__(self, title, date, details,time,district):
self.title = title
self.date = date
self.details = details
self.time = time
self.district = district
#for print
def __repr__(self):
return f'{self.title} - {self.date}: {self.time}\n {self.details}'
# In[19]:
def CB2(ical,session):
#get ical, read it as Calendar
context = ssl._create_unverified_context()
user_agent = 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.0.7) Gecko/2009021910 Firefox/3.0.7'
hdr={'User-Agent':user_agent,}
req=urllib.request.Request(ical,None,hdr)
response = urllib.request.urlopen(req,context = context).read()
cal = Calendar.from_ical(response)
events_dict = {}
#iterrate through events in cal with new events from each 'vevent'
#search for time,date, title and detaisls and add to events_dict
for i, event in enumerate(cal.walk('vevent')):
date = event.get('dtstart')
try:
time = date.dt.hour
if(date.dt.hour > 12):
time = time - 12
time = str(time)+ ":"+str(date.dt.minute).zfill(2)+" PM"
else:
time = str(time)+ ":"+str(date.dt.minute).zfill(2)+" AM"
except:
continue
location = event.get('location')
topic = event.get('summary')
description = event.get('DESCRIPTION')
events_dict[i] = {
'date': str(date.dt.month) + "/"+ str(date.dt.day),
'time': time,
'topic': str(topic).strip(),
'location': str(location),
'description': str(description).replace('\n',' ').replace('\xa0',' ').strip()
}
districtNumber = 102
#remove previous entries
session.query(Event).filter(Event.district == districtNumber).delete()
session.commit()
#add items from events_dict to database
for event in events_dict.values():
row = Event(title=event['topic'], date=event['date'],
details= f'Location: {event["location"]}\n{event["description"]}',
time=event['time'], district= districtNumber)
session.add(row)
session.commit()
# In[20]:
CB2('https://cbmanhattan.cityofnewyork.us/cb2/events/?ical=1',session)
# In[21]:
#print all users
for event in session.query(Event).filter(Event.district == 102):
print(event,'\n\n')
# In[ ]: