• 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏吧

python中django框架通过正则搜索页面上email地址的方法

PHP admin 1年前 (2018-05-31) 7次浏览 未收录 0个评论
本文实例讲述了python中django框架通过正则搜索页面上email地址的方法。分享给大家供大家参考。具体实现方法如下:

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程序设计有所帮助。


39MO , 版权所有丨如未注明 , 均为原创丨转载请注明原文链接:python中django框架通过正则搜索页面上email地址的方法
喜欢 (0)
[1353713598@qq.com]
分享 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址