本文实例讲述了python中django框架通过正则搜索页面上email地址的方法。分享给大家供大家参考。具体实现方法如下:
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
|
import re
from django.shortcuts import render
from pattern.web import URL, DOM, abs , find_urls
def index(request):
"""
find email addresses in requested url or contact page
"""
error = ''
emails = set ()
url_string = request.GET.get( 'url' , '')
EMAIL_REGEX = re. compile (r '[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,6}' , re.IGNORECASE)
# use absolute url or domain name
url = URL(url_string) if url_string.startswith( 'http' ) else URL(domain = url_string,protocol = 'http' )
if url_string:
try :
dom = DOM(url.download(cached = True ))
except Exception, e:
error = e
else :
contact_urls = { url.string }
# search links of contact page
for link in dom( 'a' ):
if re.search(r 'contact|about' , link.source, re.IGNORECASE):
contact_urls.add(
abs (link.attributes.get( 'href' ,''), base = url.redirect or url.string))
for contact_url in contact_urls:
# download contact page
dom = DOM(URL(contact_url).download(cached = True ))
# search emails in the body of the page
for line in dom( 'body' )[ 0 ].content.split( '\n' ):
found = EMAIL_REGEX.search(line)
if found:
emails.add(found.group())
data = {
'url' : url_string,
'emails' : emails,
'error' : error,
}
return render(request, 'index.html' , data)
|
希望本文所述对大家的Python程序设计有所帮助。