python爬虫(10)爬虫实例(6)

# -*- coding: utf-8 -*-

import re
import requests
import time

header = {'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36'}

f = open('斗破苍穹.txt', 'a+')

def get_info(url):
    response = requests.get(url, headers = header)
    if response.status_code == 200:
        contents = re.findall('<p>(.*?)</p>', response.content.decode('utf-8'), re.S)
        for content in contents:
            f.write('  ' + content + '\n')
        else:
            pass

if __name__ == '__main__':
    for i in range(1, 1665):
        url = 'http://www.doupoxs.com/doupocangqiong/' + str(i) + '.html'
        get_info(url)
        time.sleep(1)
f.close()

代码分析
(1)1-5行,导入必要的第三方包;给定请求头header;以“追加”的方式新建文本文档,命名为’斗破苍穹.txt’;
(2)11-18行,定义get_info()函数,获取网页信息。若网页访问的状态码为200,表示正常访问,则用re模块获取文本信息,对 response.content.decode(‘utf-8’)这个类进行findall操作,寻找格式为

(.*?)

的所有文本信息;re.S表示换行匹配。最后,将信息写入文件;
若状态码不是200,则表示网页不可访问,例如404Forbidden等。则直接pass,不进行任何操作;
(3)20-25行,定义主程序入口;对1665个可能有文本信息的页面执行get_info()函数;最后用time.sleep()做假装的睡眠,模仿浏览器访问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值