博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python从诗词名句网站中抓取四大名著之一《三国演义》!
阅读量:3962 次
发布时间:2019-05-24

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

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

@ XGan 2019 12 19

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

python代码

import randomimport requestsfrom lxml import etreehead = ["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_listdef 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
在这里插入图片描述
**

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

你可能感兴趣的文章
POSIX消息队列mq_open问题
查看>>
两个数组a[N],b[N],其中A[N]的各个元素值已知,现给b[i]赋值,b[i] = a[0]*a[1]*a[2]…*a[N-1]/a[i];
查看>>
用户态切换到内核态的3种方式
查看>>
笔试常见的智力题(附答案)
查看>>
内核库函数
查看>>
Linux 系统内核空间与用户空间通信的实现与分析
查看>>
linux内核空间和用户空间的区别及交互
查看>>
如何写好应用型学术论文
查看>>
如何查看进程的各种限制
查看>>
64位int类型用printf输出问题
查看>>
网络后台开发面试题目
查看>>
Linux 共享内存限制的查看与设置
查看>>
进程的状态转换
查看>>
如何查看进程的信息(线程数)
查看>>
read的用法
查看>>
查看系统信息(cpu,内存,硬盘,网卡)
查看>>
awk的混合编程
查看>>
awk编程
查看>>
Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
查看>>
默认shell的修改
查看>>