zoukankan      html  css  js  c++  java
  • 我是一仅仅百度贴吧的小爬虫

    整体功能:查看特定帖子楼主的发言(不包括图片)

    前段时间大概看了python的语法,可是确实第一次用python来写东西。非常久之前就想学python。学爬虫了。如今最终開始了!

    谢了自己的第一个爬虫,非常开心O(∩_∩)O 认为学东西兴趣非常重要。爬虫真的好玩!

    整个功能的实现含有两个类,一个是工具类Tool,还有一个是百度贴吧的爬虫类BaiduTieba,提取网页的内容主要还是正則表達式。代码例如以下:

    # -*- coding:utf-8 -*-
    import urllib
    import urllib2
    import re
    
    #工具类,用于去除一些链接之类的特殊标签
    class Tool:
        #去除图片链接
        removeImage = re.compile('<img class="BDE_Image".*?>')
        #去除<br>
        removeBR = re.compile('<br>')
        #去除超链接
        removeHref = re.compile('<a href=.*?</a>')
    
        def replaceStrange(self,x):
            x = re.sub(self.removeImage,"",x)
            x = re.sub(self.removeBR,"
    ",x)
            x = re.sub(self.removeHref,"",x)
            return x.strip()
    
    #百度贴吧爬虫类
    class BaiduTieba:
        def __init__(self,baseUrl,seeLZ):
            #帖子基址
            self.baseUrl = baseUrl
            #仅仅看楼主seeLZ=1
            self.seeLZ = '?see_lz='+str(seeLZ)
            self.tool = Tool()
    
        def getPage(self,pageNum):
            try:
                url = self.baseUrl + self.seeLZ + '&pn=' + str(pageNum)
                request = urllib2.Request(url)
                response = urllib2.urlopen(request)
                #print response.read()
                return response.read().decode('utf-8')
            except urllib2.URLError,e:
                if hasattr(e,"reason"):
                    print e.reason
                    return None
    
        def getTitle(self):
            page = self.getPage(1)
            pattern = re.compile('<h1 class="core_title_txt.*?>(.*?)</h1>',re.S)
            result = re.search(pattern,page)
            if result:
                print "success!"
                print result.group()
            else:
                print "failed!"
    
        def getContent(self,page):
            #正則表達式匹配
            pattern = re.compile('<div id="post_content_.*?>(.*?)</div>',re.S)
            items = re.findall(pattern,page)
            floor = 1
            for item in items:
                print '
    ',floor,u"楼-----------------------------------------------------------------------------------"
                print self.tool.replaceStrange(item)
                floor += 1
    
    print u"请输入帖子编号:"
    baseURL = 'http://tieba.baidu.com/p/' + str(raw_input(u'http://tieba.baidu.com/p/'))
    baidu = BaiduTieba(baseURL,1)
    baidu.getContent(baidu.getPage(1))
    

    效果如图(扒一扒这些年朋友之上恋人未满的逗逼):
    这里写图片描写叙述

  • 相关阅读:
    [转]Spring Cloud在国内中小型公司能用起来吗?
    [转]关于maven pom.xml中dependency type 为pom的应用
    如何直接在github网站上更新你fork的repo?
    Eclipse在Tomcat环境下运行项目出现NoClassDefFoundError/ClassNotFoundException解决办法
    Jquery mobile 中在列表项上使用单选按钮
    QBus 关注并推送实时公交信息
    常用序列号
    SVN 使用锁实现独占式签出
    SQL速记
    利用交通在手数据为换乘添加关注
  • 原文地址:https://www.cnblogs.com/clnchanpin/p/7010980.html
Copyright © 2011-2022 走看看