the5fire

关注Python、Django、Vim、Linux、Web开发、团队管理和互联网--Life is short, we need Python.


python爬虫,从sohu上抓小说《人形软件》

作者:the5fire | 标签:     | 发布:2012-02-26 12:40 a.m. | 阅读量: 11178, 10914

上次发的从sina上抓小说的代码,这次来一个sohu的,不过总结python爬虫的方法,其实无外乎urllib和正则表达式的使用。掌握了这俩,基本就是有了就抓。 直接上代码了,以下代码仅供参考,切不可用于非法用途。

.. code:: python

import urllib2
import sys
import re


def getPage(url,offset = '295'):
    realurl = "%s%s%s" %(url,offset,'.html')
    print realurl
    resp = urllib2.urlopen(realurl)
    content = resp.read()

    p = re.compile('<[^>]+>')

    #print content
    rematch = re.compile(r'(<h1.*</h1>)')
    h1 = rematch.findall(content)
    try:
        h1content = p.sub("",h1[0])
    except Exception,e:
        print str(e)
        return
    fp = open(r'renxingruanjian.txt','a')
    fp.write(h1content+ '\n')
    fp.flush()

    #print content
    content = content.replace('\r','')
    content = content.replace('\n','')
    content = content.replace(' ','')
    content = content.replace('     ','')
    #fp.write(content+'\n')
    cont = re.search('<divclass="txtC"id="txtBg">(.*)</p></div><divclass="boxA">', content, re.S)
    words = cont.group()
    p = re.compile('<[^>]+>')
    contTxt = p.sub("", words)
    #print recontent1

    fp.write(contTxt+'\n')
    fp.flush()
    fp.close()


def getBook(url, startoffset, endOffset):
    while startOffset < endOffset:
        getPage(url, offset = str(startOffset))  # 感谢网友提醒,少了个参数
        startOffset += 1

if __name__ == '__main__':
    getBook(url = 'http://lz.book.sohu.com/chapter-21882-117887', startOffset = 294, endOffset = 395)
- from the5fire.com
----EOF-----

微信公众号:Python程序员杂谈


其他分类: