Welcome, guest | Sign In | My Account | Store | Cart

This is a quick and dirty script that does not use google REST api so use this with warning. It extracts emails from google search results. http://pantuts.com/2013/03/20/emingoo-extract-emails-from-google-search-results/

Python, 74 lines
 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
#!/usr/bin/python3
# -*- coding: utf-8 -*-
# Name: emingoo.py
# Version: 1.0
# Author: pantuts
# Description: Extract emails from Google search results.
# Agreement: You can use, modify, or redistribute this tool under the terms of GNU General Public License (GPLv3).
# This tool is for educational purposes only. Any damage you make will not affect the author.

import sys, re, time
from urllib.request import Request, urlopen
import urllib.error

def helper():
	print('Usage:./emingoo.py -d domainToSearch -c maxResults[int]')
	print('Default min google search result is 100 and max is 10000.')
	print()

def extract(res, d):
	em_sub = re.sub('<[^<]+?>', '', res) # strip all html tags like <em>
	tmp_emails = re.findall(r'[a-zA-Z0-9._%+-]+@[a-zA-Z0-9._%+-]+' + d, em_sub)
	tmp_emails1 = re.findall(r'[a-zA-Z0-9._%+-]+@' + d, em_sub)
	tmp_emails2 = set(tmp_emails + tmp_emails1)
	emails = [x for x in tmp_emails2]
	if len(emails) == 0: print('Sorry, no results found.')
	else:
		for i in emails: print(i); time.sleep(0.01)
	print()

def crawl(d, c):
	if c > 10000:
		print('Sorry your argument -c exceeded on its max search result.')
		sys.exit(0)
	print('Searching emails for ' + d + ' ...')
	print()
	try:
		q = 'http://www.google.com/search?hl=en&num=' + str(c) + '&q=intext%3A%40' + d + '&ie=utf-8'
		req = Request(q)
		req.add_header('User-Agent', 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:19.0) Gecko/20100101 Firefox/19.0')
		res = urlopen(req).read().decode('utf-8')
	except (urllib.error.URLError, urllib.error.HTTPError) as e:
		print(e)
		sys.exit(1)

	extract(res, d)

def main():
	if len(sys.argv) < 3 or len(sys.argv) > 5:
		helper()
		sys.exit(0)
	else:
		if len(sys.argv) == 5:
			domain = sys.argv[2]
			max_res = int(sys.argv[4])
		elif len(sys.argv) == 3:
			domain = sys.argv[2]
			max_res = 100
		else:
			helper()
			sys.exit(0)

	crawl(domain, max_res)

if __name__=='__main__':
	print(' ____  __  __  ____  _  _  ___  _____  _____ ')
	print('( ___)(  \/  )(_  _)( \( )/ __)(  _  )(  _  )')
	print(' )__)  )    (  _)(_  )  (( (_-. )(_)(  )(_)( ')
	print('(____)(_/\/\_)(____)(_)\_)\___/(_____)(_____)')
	print()
	try:
		main()
	except KeyboardInterrupt:
		print('\rKeyboardInterrupt')
		sys.exit(0)

2 comments

Bill Hallahan 10 years, 11 months ago  # | flag

I am sure that anyone looking at this recipe will realize that this extracts 'email addresses', not 'emails' from Google search results.

The title got my interest because I was both concerned and curious about how one could find 'emails' with Google. I'm glad to see that isn't what this does!

p@ntut$ (author) 10 years, 11 months ago  # | flag

You're being funny man :)

Created by p@ntut$ on Wed, 20 Mar 2013 (GPL3)
Python recipes (4591)
p@ntut$'s recipes (7)

Required Modules

  • (none specified)

Other Information and Tasks

  • Licensed under the GPL 3
  • Viewed 11137 times
  • Revision 2 (updated 9 years ago)