-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpermission_info.py
45 lines (37 loc) · 1.47 KB
/
permission_info.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
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from bs4 import BeautifulSoup
import time
CHROME_DRIVER_PATH = '/Users/grtushar/Documents/libs/chromedriver'
TIME_TO_LOAD_DATE_IN_SECOND = 5
TIME_TO_LOAD_MODAL_DATA_IN_SECOND = 5
MAX_ATTEMPT = 100
options = Options()
options.headless = True
driver = webdriver.Chrome(CHROME_DRIVER_PATH, options=options)
def get_permission_info(url):
ret = ""
attempt = 1
while True:
driver.get(url)
time.sleep(TIME_TO_LOAD_DATE_IN_SECOND)
driver.find_element_by_link_text("View details").click()
time.sleep(TIME_TO_LOAD_MODAL_DATA_IN_SECOND)
soup = BeautifulSoup(driver.page_source, "lxml")
permission_sub_lists = soup.find_all('ul', {'class': 'GLaCt'})
permission_contents = []
for contents in permission_sub_lists:
plain_contents = []
for data in contents.find_all('li'):
plain_contents.append(data.text)
permission_contents.append(plain_contents)
permission_list = soup.find_all('span', {'class': 'SoU6Qc'})
for i in range(0, len(permission_list)):
permission = permission_list[i]
ret += permission.text + "\n"
for sublistContent in permission_contents[i]:
ret += sublistContent + "\n"
if (len(permission_list) > 0 and len(permission_sub_lists)) or attempt > MAX_ATTEMPT:
break
attempt += 1
return ret