Python从诗词名句网站中抓取四大名著之一《三国演义》!

从诗词名句网站中抓取四大名著之一三国演义,并保存!

@ XGan 2019 12 19

**抓取诗词网站(http://www.shicimingju.com/book/sanguoyanyi.html)中的四大名著,并保存到本地文件中,使用该代码可以抓取诗词网上很多的古典诗集的,只需做稍微的修改,但都只支持单部书籍的爬取,等有时间写一个全网爬取的Demo,到时候与大家分享,这里只是以《三国演义》爬取为例。
python代码

import random
import requests
from lxml import etree

head = [
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36",
"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36"
]

def get_html(url):  #获取每一章节的链接
    res = requests.get(url,headers={
        'User-Agent':random.choice(head)
    }).text
    html = etree.HTML(res)
    # 得到每一章节的链接
    url_list = html.xpath("//div[@class='book-mulu']/ul/li/a/@href")
    return url_list
def get_chapter_content(url_list): #对每一章节发起请求,并提取title,text内容,保存在txt中
    with open('./data/三国演义.txt','w',encoding='utf-8') as f:
        print(50 * '*' + "开始抓取" + 50 * '*')
        for u in url_list:
            url = 'http://www.shicimingju.com' +u
            res = requests.get(url,headers={
                'User-Agent':random.choice(head)
            }).text
            html = etree.HTML(res)
            # 获取每张标题
            title = html.xpath("//div[@class='card bookmark-list']/h1/text()")
            print(title[0]+"\n")
            f.write(str(title[0])+"\n")
            p_list = html.xpath("//div[@class='chapter_content']//p")
            for p in p_list:
                # 获取每章内容
                text = p.xpath("./text()")[0]
                f.write(str(text)+"\n")
                print(text)

        print(50 * '*' + "抓取成功" + 50 * '*')
if __name__ == '__main__':
    url ='http://www.shicimingju.com/book/sanguoyanyi.html'
    urllist =  get_html(url)
    get_chapter_content(urllist)

结果

在这里插入图片描述
在这里插入图片描述

目标网站:http://www.shicimingju.com/book/sanguoyanyi.html
在这里插入图片描述
使用xpath提取网页中的想要的信息
每一个章节可从首页获得,xpath为//div[@class=‘book-mulu’]/ul/li/a/@href
在这里插入图片描述
每一个章节的标题可由xpath提取为//div[@class=‘card bookmark-list’]/h1/text()
在这里插入图片描述
每一个章节的内容可由xpath提取为//div[@class=‘chapter_content’]//p/text()
在这里插入图片描述
到此完成,整本《三国演义》不大才1.7M
在这里插入图片描述
**

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值