博客
关于我
Python 爬取起点的小说(非vip)
阅读量:357 次
发布时间:2019-03-04

本文共 1978 字,大约阅读时间需要 6 分钟。

Python 爬取小说章节(非VIP)- 以《冒牌大英雄》为例

本文将介绍如何使用Python编写一个爬取小说章节的脚本。以《冒牌大英雄》为例,讲述从非VIP章节爬取小说内容的实现方法。通过本地存储每个章节的内容,生成HTML格式的文件。

技术选型

本次实现使用了以下技术和工具:

  • 第三方库requests,用于发送HTTP请求,抓取网页内容
  • 正则表达式:用于解析网页源代码,提取章节链接
  • 文件存储:将爬取到的内容存储为本地文件
  • 爬取流程

    完整的爬取流程如下:

  • 获取起始网址的网页源代码
  • 从源代码中提取章节链接
  • 循环处理每个章节链接
    • 提取每个章节的标题
    • 提取每个章节的内容
    • 保存为本地文件
  • 文件命名规则
    • 文件名由标题加时间戳组成
    • 保存格式为HTML文件
  • 实现细节

    1. 获取起始网址的网页源代码

    使用requests库发送HTTP GET请求,获取起始网址的网页源代码。同时,设置合理的请求头信息,避免被网站反爬机制拦截。

    import requestsimport reurl = 'https://book.qidian.com/info/131957'headers = {    'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36',    'accept-encoding': 'gzip, deflate, sdch, br',    'accept-language': 'zh-CN,zh;q=0.8'}response = requests.get(url, headers=headers)response.encoding = 'utf-8'response_text = response.text

    2. 提取章节链接

    网页源代码中通常嵌入了章节链接,可以通过正则表达式提取。常见的提取方式包括:

    • 查找特定的a标签
    • 查找特定的li列表
    • 使用动态加载的内容(如data-rid属性)
    pat = r'
  • 'links = re.findall(pat, response_text)

    3. 循环处理每个章节链接

    对于每个找到的章节链接,重复以下步骤:

  • 发送HTTP GET请求,获取章节网页的内容
  • 提取标题和内容
  • 保存为本地文件
  • for link in links:    # 发送请求获取章节内容    chapter_url = 'https://book.qidian.com' + link    chapter_response = requests.get(chapter_url, headers=headers)    chapter_response.encoding = 'utf-8'    chapter_text = chapter_response.text        # 提取标题和内容    title_pat = r'

    (.*?)

    ' content_pat = r'(?<=
    ).*?(?=<\/content>)' title = re.search(title_pat, chapter_text).group(1) content = re.search(content_pat, chapter_text).group(0) # 保存文件 filename = f'"{title}"_{int(time.time())}.html' with open(filename, 'w', encoding='utf-8') as f: f.write(f'

    {title}

    {content}')

    4. 文件命名规则

    为确保每个文件唯一,可以在标题中添加时间戳。这样即使同一标题的章节多次爬取,也能生成不同的文件名。

    import timefilename = f'"{title}"_{int(time.time())}.html'

    注意事项

  • 反爬机制:部分网站会通过检测代理IP或请求频率来限制爬取行为。可通过设置代理IP池或模拟真实用户行为来规避。
  • 网络限制:部分网站会限制爬虫的并发请求量。可以通过requests库的timeout参数设置请求超时。
  • 内容变更:网站内容可能会定期更新,导致爬取的内容与实际页面有差异。建议定期检查和更新爬虫规则。
  • 通过以上方法,可以轻松实现爬取小说章节的需求。整个流程从获取源代码到存储本地文件,都可以通过Python脚本实现,满足批量处理和自动化的需求。

    转载地址:http://kokr.baihongyu.com/

    你可能感兴趣的文章
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>
    Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
    查看>>
    Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
    查看>>
    Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
    查看>>
    Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
    查看>>
    Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
    查看>>
    Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    Openmax IL (二)Android多媒体编解码Component
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>