-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathscrape.py
42 lines (40 loc) · 1.56 KB
/
scrape.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
from selenium import webdriver
from selenium.webdriver.common.by import By
import json
import time
from scrappers.devfolio import Devfolio
def scrape_data():
options = webdriver.ChromeOptions()
options.add_argument('--ignore-ssl-errors=yes')
options.add_argument('--ignore-certificate-errors')
driver = webdriver.Remote(
command_executor='http://localhost:4444/wd/hub',
options=options
)
driver.get("https://mlh.io/seasons/2024/events")
links = driver.find_elements(By.CLASS_NAME, "event-link") # Fetching links of hackathon websites
images = driver.find_elements(By.CSS_SELECTOR, ".image-wrap img") # Fetching images of hackathons
names = driver.find_elements(By.CLASS_NAME, "event-name") # Fetching names of hackathons
dates = driver.find_elements(By.CLASS_NAME, "event-date") # Fetching dates
locs = driver.find_elements(By.CLASS_NAME, "event-location") # Fetching location
modes = driver.find_elements(By.CLASS_NAME,"event-hybrid-notes") # Fetching modes
hackathons = []
for i in range(len(links)):
hackathon = {
"name": names[i].text,
"link": links[i].get_attribute("href"),
"image": images[i].get_attribute("src"),
"date": dates[i].text,
"location": locs[i].text,
"mode":modes[i].text
}
hackathons.append(hackathon)
with open("hackathons.json","w") as f:
json.dump(hackathons,f,indent=4);
driver.quit()
# scrape_data()
while(1):
scrape_data()
devfolio=Devfolio()
devfolio.findall()
time.sleep(86400)