-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcollect_followers.py
76 lines (70 loc) · 2.99 KB
/
collect_followers.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
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.chrome.options import Options
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import TimeoutException
import time
import re,getpass,csv
import datetime
import random
def screenpos():
driver.maximize_window()
driver.set_window_size(4031,1031)
driver.set_window_position(-8,0)
time.sleep(1)
# PATH = "chromedriver"
PATH = "/home/captain/Social Networks/Soical Project/Data Collection/chromedriver"
with open("/home/captain/Social Networks/Soical Project/Data Collection/urls.txt") as f:
lines = f.read().splitlines()
check = 0
for url in lines:
driver = webdriver.Chrome(PATH)
screenpos()
driver.implicitly_wait(1)
driver.get(url)
link = driver.find_element_by_css_selector('#js-repo-pjax-container > div.container-xl.clearfix.new-discussion-timeline.px-3.px-md-4.px-lg-5 > div > div.gutter-condensed.gutter-lg.flex-column.flex-md-row.d-flex > div.flex-shrink-0.col-12.col-md-3 > div')
link = link.find_element_by_partial_link_text('Contributors') #div.BorderGrid-cell > h2.h4 > a[class="link-gray-dark no-underline "]
print(link.text)
try:
repo_contributors = WebDriverWait(driver,6,0.5).until(
EC.presence_of_element_located((By.LINK_TEXT, link.text)),
)
repo_contributors.click()
except TimeoutException:
pass
num_contributors = WebDriverWait(driver,100).until(
EC.presence_of_all_elements_located((By.XPATH, '//*[@id="contributors"]/ol/li/span/h3/a[2]')),
)
length = len(num_contributors)
if(length > 1000):
length = 1000
data = open("followerdata.txt", 'a')
for x in range(length): #len(contributor_repos)
data.write('\n')
path = '//*[@id="contributors"]/ol/li['+str(x+1)+']/span/h3/a[2]'
try:
contributor = WebDriverWait(driver,100).until(
EC.presence_of_element_located((By.XPATH, path)),
)
data.write(contributor.text)
contributor.click()
except TimeoutException:
pass
user_followers = []
find = driver.find_element_by_partial_link_text("follower")
find.click()
try:
user_followers = WebDriverWait(driver,50).until(
EC.presence_of_all_elements_located((By.CSS_SELECTOR, '#js-pjax-container > div.container-xl.px-3.px-md-4.px-lg-5 > div > div.flex-shrink-0.col-12.col-md-9.mb-4.mb-md-0 > div:nth-child(2) > div > div > div.d-table-cell.col-9.v-align-top.pr-3 > a > span.f4.link-gray-dark ')),
)
for repo in user_followers:
if(repo.text != ''):
data.write(" "+repo.text)
except TimeoutException:
print("Not found")
pass
driver.back()
driver.back()
driver.quit()