-
Notifications
You must be signed in to change notification settings - Fork 286
/
fetchComments
110 lines (95 loc) · 3.17 KB
/
fetchComments
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
# with this code, you can open any photo from any profile and Fetch all the comments on it
from time import sleep
from selenium import webdriver
import getpass
import csv
print("Username:", end="")
username = str(input())
pas = getpass.getpass()
# pas = str(input())
print("Username of Person whose Photo you want to access:", end="")
spy = str(input())
print("Image Number(from Recent): ", end="")
ic = int(input())
print("Would you like to get Comments in excel document:(Y/N) ", end="")
excel = str(input())
browser = webdriver.Firefox(executable_path=r'C:\Users\HP\AppData\Local\Programs\Python\Python38-32\Lib\site-packages\selenium\webdriver\firefox\geckodriver.exe')
browser.get('https://www.instagram.com/')
sleep(2)
name = browser.find_element_by_xpath('/html/body/div[1]/section/main/article/div[2]/div[1]/div/form/div[2]/div/label/input')
name.send_keys(username)
password = browser.find_element_by_xpath('/html/body/div[1]/section/main/article/div[2]/div[1]/div/form/div[3]/div/label/input')
password.send_keys(pas)
sleep(2)
try:
signin = browser.find_element_by_xpath('/html/body/div[1]/section/main/article/div[2]/div[1]/div/form/div[4]/button')
signin.click()
except:
print("Invalid username or password")
exit()
sleep(5)
try:
browser.get('https://www.instagram.com/'+spy)
except:
print('Invalid Username')
exit()
r = ic//3
r = r + 1
c = ic%3
if c == 0:
c = 3
sleep(5)
try:
im = '/html/body/div[1]/section/main/div/div[3]/article/div[1]/div/div['+str(r)+']/div['+str(c)+']/a/div/div[2]'
img = browser.find_element_by_xpath(im)
except:
print('Login Failed or Private Account')
exit()
img.click()
sleep(3)
if 1 in choice:
sleep(2)
like = browser.find_element_by_xpath('/html/body/div[4]/div[2]/div/article/div[2]/section[1]/span[1]/button')
like.click()
sleep(1)
if 2 in choice:
try:
browser.find_element_by_xpath('/html/body/div[4]/div[2]/div/article/div[2]/section[1]/span[2]/button').click()
comment_box = browser.find_element_by_xpath('/html/body/div[4]/div[2]/div/article/div[2]/section[3]/div/form/textarea')
comment_box.send_keys(str(comm))
sleep(1)
browser.find_element_by_xpath('/html/body/div[4]/div[2]/div/article/div[2]/section[3]/div/form/button').click()
except:
print('Error in Commenting')
sleep(1)
if excel == 'Y':
CName = []
CD = []
i = 1
print("\n-----------Comments--------------\n")
while True:
try:
cb = '/html/body/div[4]/div[2]/div/article/div[2]/div[1]/ul/ul['+str(i)+']/div/li/div/div[1]/div[2]/h3/div/a'
cn = browser.find_element_by_xpath(cb)
print(cn.text, end=" - ")
CName.append(cn.text)
y = '/html/body/div[4]/div[2]/div/article/div[2]/div[1]/ul/ul['+str(i)+']/div/li/div/div[1]/div[2]/span'
c = browser.find_element_by_xpath(y)
print(c.text)
CD.append(c.text)
i += 1
sleep(0.5)
try:
browser.find_element_by_xpath('/html/body/div[4]/div[2]/div/article/div[2]/div[1]/ul/li/div/button').click()
except:
pass
except Exception as e:
break
if excel == 'Y':
file = open('Comments.csv', 'w', encoding="utf-8", newline='')
writer = csv.writer(file)
writer.writerow(['User','Comment'])
for i in range(len(CD)):
writer.writerow([str(CName[i]),str(CD[i])])
print('\nDone! File Created With name Comments.csv')
file.close()