您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python通过urllib2爬网页上种子下载示例

5b51 2022/1/14 8:17:40 python 字数 6531 阅读 351 来源 www.jb51.cc/python

通过urllib2、re模块抓种子 思路 1.用程序登录论坛(如果需要登录才能访问的版块)

概述

通过urllib2、re模块抓种子

思路

1.用程序登录论坛(如果需要登录才能访问的版块)

2.访问指定版块

3.遍历帖子(先取指定页,再遍历页面所有帖子的url)

4.循环访问所有帖子url,从帖子页面代码中取种子下载地址(通过正则表达式或第三方页面解析库)

5.访问种子页面下载种子

# site is website address | fid is part id
site = "http://xxx.yyy.zzz/"
source = "thread0806.PHP?fid=x&search=&page="

btSave = "./clyzwm/"
if os.path.isdir(btSave):
 print btSave + " existing"
else:
 os.mkdir(btSave)

logfile = "./clyzwm/down.log"
errorfile = "./clyzwm/error.log"
sucfile = "./clyzwm/sucess.log"

headers = {'User-Agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/32.0.1700.77 Safari/537.36', 
           'Referer' : 'http://xxx.yyy.zzz/'}

def btDown(url,dirPath):
 logger(logfile,"download file : " + url)
 try:
  #pageCode = urllib2.urlopen(url).read()
  #print pageCode
  btStep1 = re.findall('http://[\w]+\.[\w]+\.[\w]{0,4}/[\w]{2,6}\.PHP\?[\w]{2,6}=([\w]+)',url,re.I)
  #print btStep1
  if len(btStep1)>0:
   ref = btStep1[0]
   downsite = ""
   downData = {}
   if len(ref)>20:
    downsite = re.findall('http://www.[\w]+\.[\w]+/',url)[0]
    downsite = downsite + "download.PHP"
    reff = re.findall('input\stype=\"hidden\"\sname=\"reff\"\svalue=\"([\w=]+)\"',urllib2.urlopen(url).read(),re.I)[0]
    downData = {'ref': ref,'reff':reff,'submit':'download'}
   else:
    downsite = "http://www.downhh.com/download.PHP"
    downData = {'ref': ref,'rulesubmit':'download'}
   #print "bt site - " +  downsite + "\n downData:"
   #print downData
   downData = urllib.urlencode(downData)
   downReq = urllib2.Request(downsite,downData)
   downReq.add_header('User-Agent','Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML,like Gecko) Chrome/32.0.1700.77 Safari/537.36')
   downPost = urllib2.urlopen(downReq)
   stream = downPost.read(-1)
   if (len(stream) > 1000):
    downPost.close()
    name = btStep1[0]+ ".torrent"
    fw = open(dirPath + name,'w')
    fw.write(stream)
    fw.close()
    logger(sucfile,url+"\n")
   else:
    logger(errorfile,url+"\n")
 except urllib2.URLError,e:
  print e.reason

def logger(logfile,msg):
 print msg
 fw = open(logfile,'a')
 fw.write(msg)
 fw.close()

for i in range(1,1000):
 logger(logfile,"\n\n\n@ page " + str(i) + " ...")
 part = site + source + str(i)

 content = urllib2.urlopen(part).read()
 content = content.decode('gbk').encode('utf8')
 #print content

 pages = re.findall('<a\s+href=\"(htm_data/[\d]+/[\d]+/[\d]+\.html).*?<\/a>',content,re.I)
 #print pages

 for page in pages:
  page = site + page;
  #logger(logfile,"\n# visiting " + page + " ...")
  pageCode = urllib2.urlopen(page).read()
  #print pageCode
  zzJump = re.findall('http://www.viidii.info/\?http://[\w]+/[\w]+\?[\w]{2,6}=[\w]+',pageCode)  
  #zzJump = re.findall('http://www.viidii.info/\?http://[\w/\?=]*',pageCode)
  if len(zzJump) > 0:
   zzJump = zzJump[0]
   #print "- jump page - " + zzJump
   pageCode = urllib2.urlopen(page).read()
   zzPage = re.findall('http://[\w]+\.[\w]+\.[\w]+/link[\w]?\.PHP\?[\w]{2,pageCode)
   if len(zzPage) > 0:
    zzPage = zzPage[0]
    logger(logfile,"\n- zhongzi page -" + zzPage)
    btDown(zzPage,btSave)
   else:
    logger(logfile,"\n. NOT FOUND .")
  else:
   logger(logfile,"\n... NOT FOUND ...")
  zzPage = re.findall('http://[\w]+\.[\w]+\.[\w]+/link[\w]?\.PHP\?ref=[\w]+',pageCode)

总结

以上是编程之家为你收集整理的python通过urllib2爬网页上种子下载示例全部内容,希望文章能够帮你解决python通过urllib2爬网页上种子下载示例所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶