-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlinkedin_bot.py
97 lines (82 loc) · 3.49 KB
/
linkedin_bot.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
import pandas
from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException, InvalidArgumentException
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.firefox.service import Service
from selenium.webdriver.support.ui import Select
from time import sleep
def check_exists_by_xpath(browser,xpath):
try:
browser.find_element(By.XPATH,xpath)
except NoSuchElementException:
return False
return True
def check_exists(element,browser,sel):
try:
browser.find_element(element,sel)
except NoSuchElementException:
return False
return True
def login(browser):
url = "https://www.linkedin.com/"
browser.get(url)
username = browser.find_element(By.ID,"session_key") # Getting the login element
username.send_keys("<Enter email id>") # Sending the keys for username
password = browser.find_element(By.ID,"session_password") # Getting the password element
password.send_keys("<Enter password") # Sending the keys for password
browser.find_element(By.CLASS_NAME,"sign-in-form__submit-button").click() # Getting the tag for submit button
def connection_request(browser, profile_url_list):
for profile_url in profile_url_list:
print(profile_url)
if not profile_url or profile_url == '' or pandas.isnull(profile_url):
print("Empty String\n")
continue
try:
browser.get(profile_url)
except InvalidArgumentException:
print("Bad profile URL\n")
continue
sleep(10)
xpath="//main[@id='main']/section[1]/div[2]/div[3]/div[1]/button[1]/span[contains(.,'Connect')]"
connect_xpath="//main[@id='main']/section[1]/div[2]/div[3]/div[1]/button[1]"
more_xpath="//main[@id='main']/section[1]/div[2]/div[3]/div[1]//button[contains(@aria-label, 'More actions')]"
more_connect_xpath="//main[@id='main']/section[1]/div[2]/div[3]/div[1]//button[contains(@aria-label, 'More actions')]/parent::node()/div/div/ul//div/span[text()='Connect']"
if check_exists_by_xpath(browser,xpath):
browser.find_element(By.XPATH,connect_xpath).click()
check_popup(browser)
print("Connected\n")
elif check_exists_by_xpath(browser, more_xpath):
browser.find_element(By.XPATH,more_xpath).click()
if check_exists_by_xpath(browser, more_connect_xpath):
browser.find_element(By.XPATH,more_connect_xpath).click()
check_popup(browser)
print("Connected\n")
else:
print("No connection option under More button\n")
else:
print("No connection option under profile action flex\n")
def check_popup(browser):
if check_exists(By.CSS_SELECTOR,browser,'[aria-label="Send now"]'):
browser.find_element(By.CSS_SELECTOR,'[aria-label="Send now"]').click()
elif check_exists(By.CSS_SELECTOR,browser,'[aria-label="Other"]'):
browser.find_element(By.CSS_SELECTOR,'[aria-label="Other"]').click()
browser.find_element(By.CSS_SELECTOR,'[aria-label="Connect"]').click()
check_popup(browser)
elif check_exists(By.CSS_SELECTOR,browser,'[aria-label="Connect"]'):
browser.find_element(By.CSS_SELECTOR,'[aria-label="Connect"]').click()
check_popup(browser)
return
def main():
# get profile url list from excel
linkedin_database = pandas.read_csv("linkedin_database.csv")
profile_url_list = list(linkedin_database.iloc[0:, 2])
# connect python with webbrowser-firefox
service = Service('geckodriver-v0.31.0-win64\\geckodriver.exe') # path to browser web driver
browser = webdriver.Firefox(service=service)
login(browser)
connection_request(browser, profile_url_list)
browser.quit()
# Driver's code
if __name__ == '__main__':
main()