Python小爬虫-自动下载三亿文库文档

  新手学python,写了一个抓取网页后自动下载文档的脚本,和大家分享。

       首先我们打开三亿文库下载栏目的网址,比如专业资料(IT/计算机/互联网)http://3y.uu456.com/bl-197?od=1&pn=0,可以观察到链接中pn=后面的数字就是对应的页码,所以一会我们会用iurl = ‘http://3y.uu456.com/bl-197?od=1&pn=‘,后面加上页码来抓取网页.

       一般网页会用1,2,3...不过机智的三亿文库用0,25,50...来表示,所以我们在拼接url时还得转换一下。

       右键查看网页源代码,可以观察到这里每一个文档都用一个<a>标签标记,href对应文档的链接,title是文档名字,我们只需要用正则表达式将其“扣”出来就可以了.

       不过你会发现我们扣出来的文档地址eg:"bp-602d123348d7c1c708a14sqb-1.html", 并不是真正的文档下载地址,进一步点击文档至下载页面,我们可以发现文档真正的下载路径是:“dlDoc-602d123348d7c1c708a14sqb-1-toword.doc”,清晰易见,我们只需提取文档序号602d123348d7c1c708a14sqb-1,再拼接起来便OK了。

<p>
  <a href="bp-602d123348d7c1c708a14sqb-1.html" title="视频会议系统" target="_blank">视频会议系统</a>
</p>
<a rel="nofollow" target="_blank" href="dlDoc-602d123348d7c1c708a14sqb-1-toword.doc">视频会议系统-第1页.doc</a>

运行结果如下:

代码如下:

# -*- coding: utf-8 -*-  
#----------------------------------------------------- 
#   功能:将访问的页面存储为html文件,并将页面内的文档下载至本地 
#   作者:chenbjin 
#   日期:2014-07-10  
#   语言:Python 2.7.6    
#-----------------------------------------------------

import string
import urllib
import urllib2
import re
import os

#函数功能:抓取begin-end页面,存入threeuPage文件夹中,并将其中的文档下载到threeuFile文件夹中。
def threeu_page(burl,url,begin_page,end_page) :
    
    #The directory to save web page
    sPagePath = ./treeuPage
    if not os.path.exists(sPagePath) : 
        os.mkdir(sPagePath)

    #The director to save downloaded file
    sFilePath = ./threeuFile
    if not os.path.exists(sFilePath) : 
        os.mkdir(sFilePath)

    for i in range(begin_page,end_page+1) :
pn = (i-1)*25
#自动填充成六位的文件名,eg:00001.html sName = sPagePath + /+ string.zfill(i,5) + .html print Spidering the + str(i) + page ,saved to + sName + ... f = open(sName,w+) user_agent = Mozilla/4.0 (compatible; MSIE 5.5; Windows NT) headers = { User-Agent : user_agent } request = urllib2.Request(url+str(pn),headers = headers) try: con = urllib2.urlopen(request, timeout=10).read() #正则匹配出文档的地址 myItems = re.findall(<a href="bp-(.*?).html" title="(.*?)" target="_blank">(.*?)</a>,con,re.S) #print "Total : ",len(myItems) for item in myItems : print Dowloading the +item[0] + " "+ item[1].decode(gbk) + ... #下载文档 durl = burl+item[0]+-toword.doc urllib.urlretrieve(durl,sFilePath+/+item[1].decode(gbk)+.doc) except urllib2.URLError,e : print e else: f.write(con) f.close() #这是三亿文库中“专业资料 > IT/计算机 > 互联网”的地址 burl = http://3y.uu456.com/dlDoc- iurl = http://3y.uu456.com/bl-197?od=1&pn= ibegin = 1 iend = 1 threeu_page(burl,iurl,ibegin,iend) #end

   参考资料:

        1.Python爬虫入门教程:http://blog.csdn.net/column/details/why-bug.html

Python小爬虫-自动下载三亿文库文档,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。