域名过期提前预警脚本

#!/root/.virtualenvs/script/bin/python#coding=utf-8import re

import time, mechanize

import urllib2

import random

URL = 'http://whois.chinaz.com/'def str_cut(str,startsep,endsep):

    str1=str.split(startsep)[1]

    str2=str1.split(endsep)[0]return str2

br = mechanize.Browser()

br.set_handle_equiv(True)

br.set_handle_gzip(False)

br.set_handle_redirect(True)

br.set_handle_referer(True)

br.set_handle_robots(True)

br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)#br.set_debug_http(True)#br.set_debug_redirects(True)#br.set_debug_responses(True)br.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.

1')]

domain_list = [你的域名列表]

r = br.open(URL)for index, item in enumerate(domain_list):

    try:

        br.select_form(nr=0)

        br.form['DomainName'] = item

        br.submit()

        contents = br.response().read()if contents.find('<div id="whoisinfo" class="div_whois">')==-1:print item +  " " + "not found"else:

            contents=str_cut(contents,'<div id="whoisinfo" class="div_whois">','</div>')

            contents=contents.replace('<br/>',',')[:-1]

            a = re.split(',',contents)for i in a:m = re.match(r"过期时间", i)if m:print '域名 : %s, 过期时间 : %s' % (item, re.sub(r"年|月", '-', i[15:-3]).strip()[:10])

        br.back()

    except Exception,e:print Exception,":",etime.sleep(1.27*random.randint(4, 12))
上一篇:(转)Delphi 和 Windows API


下一篇:python gotoxy