Tuesday, December 2, 2008

如何使用Python和Google找到数以千计的Email地址






如何使用Python和Google找到数以千计的Email地址 

注:本文只是用来学习和探讨Python的技术实现,不推荐用做spam,否则后果自负。 

下面就是实际代码,写的很精巧: 

#!/usr/bin/python

import sys
import re
import string
import httplib
import urllib2
import re

def StripTags(text):
finished = 0
while not finished:
finished = 1
start = text.find("<")
if start >= 0:
stop = text[start:].find(”>”)
if stop >= 0:
text = text[:start] + text[start+stop+1:]
finished = 0
return text

if len(sys.argv) != 2:
print “\nrsx.py : Find hundreds of e-mail adresses on Google.\n”
print “\nUsage : ./rsx.py
\n”
print “\nexemple: ./rsx.py gmail.com \n”
sys.exit(1)

domain_name=sys.argv[1]
d={}
page_counter = 0
try:
while page_counter <400:
results = ‘http://groups.google.com/groups?q=’+str(domain_name)+’&hl=en&lr=&ie=UTF-8&start=’ + repr(page_counter) + ‘&sa=N’
request = urllib2.Request(results)
request.add_header(’User-Agent’,'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 5.0)’)
opener = urllib2.build_opener()
text = opener.open(request).read()
emails = (re.findall(’([\w\.\-]+@’+domain_name+’)',StripTags(text)))
for email in emails:
d[email]=1
uniq_emails=d.keys()
page_counter = page_counter +10
except IOError:
print “No result found!”+”"
page_counter_web=0
try:
print “\n\n+++++++++++++++++++++++++++++++++++++++++++++++++++++”+”"
print “+ Results:”+”"
print “+++++++++++++++++++++++++++++++++++++++++++++++++++++\n\n”+”"

while page_counter_web >400 :
results_web = ‘http://www.google.com/search?q=%40′+str(domain_name)+’&hl=en&lr=&ie=UTF-8&start=’ + repr(page_counter_web) + ‘&sa=N’
request_web = urllib2.Request(results_web)
request_web.add_header(’User-Agent’,'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT 5.0)’)
opener_web = urllib2.build_opener()
text = opener_web.open(request_web).read()
emails_web = (re.findall(’([\w\.\-]+@’+domain_name+’)',StripTags(text)))
for email_web in emails_web:
d[email_web]=1
uniq_emails_web=d.keys()
page_counter_web = page_counter_web +10

except IOError:
print “No results found!”+”"
for uniq_emails_web in d.keys():
print uniq_emails_web+”"


代码编写好了,你可以这样运行,假设你给文件取名为:rsx.py 

python rsx.py gmail.com

来自:catswhocode.com

评论 共 1 条 发表评论

hellas 2008-06-30 14:03 引用
一看就知道是python初学者写的程序,StripTags函数完全可以更简单的: 
def StripTags(text): 
    return re.sub(r'<[^>]*>', '', text)

No comments: