第六讲:

  今天我们来实战一个项目,我本人比较喜欢看小说,有一部小时叫《圣墟》不知道大家有没有听说过,个人觉得还是不错的,现在联网的时候,都可以随时随地用手机打开浏览器搜索查看,但是有时候也会遇到没有网络的情况,这个就很扎心了,有什么办法呢?所以这个项目基于这么一个现实背景来分析实现一下,把我们前几次讲到一些技术方法都运用一遍。

  (有人可能会说直接下载一个txt格式的小说文本文件不就好了,虽然是挺方便的,但是懒惰是不好的习惯,而且也没有运用到所学的知识,那么我们何必要学习呢?为什么要学,看完实例就知道了!)

  现在开始我们的实战项目,首先我们想到我们的爬虫可以访问到一个网站,能把网站的HTML文本内容中有用的信息提取处理,如果我们需要的小说的内容都在这个文本里面就好了,那么我们实现起来就比较容易,毕竟我们之前都学过怎么爬取,假如我们爬取到了内容,这些内容又应该怎么保存起来呢,这里就想到了文件处理,把小说内容都转储到一个txt文件里面。

  首先有了这么一个大概思路:

  ①   爬取小说网页的内容

  ②   转储到一个txt文件里面

  我们来详细分析第一个步骤,既然是要爬取小说的网页,那么我们就要选择一个比较容易爬取的网站,这里我们经过多次审查,最终确定了一个网   站:http://www.biqiuge.com/book/4772/

  名字叫笔趣阁,这个网页有所有章节的网站,那么我们就可以根据每个章节对应的一个网页进行内容爬取,简单来说就是第一大步骤里面又分为两个小步骤,首先是爬取所有章节的url链接,然后根据每个url链接再爬取相应章节的内容。

  下面对网页html进行详细分析,

  由图可以看出在<div class=”listmain”>标签里面包含了所有我们要提取章节url链接的信息,但是有点小麻烦就是有一个最新章节的列表和正文列表是同一个等级排列,如果我们直接用BeautifulSoup中的find_all()方法的话,会把最新章节列表的内容也包含进来,这里就需要我们能把最新章节列表和正文列表的url进行分离了。

  通过前五章的url链接我们可以清楚看到,每个章节不同的只是4472/后面的数字,那么我们是不是可以用re模块创建一个正则表达式对象来提取呢?

  好的,带着想法我们进入IDE环境,进行我们的编码:

  首先搭建好我们的代码框架

 1 import requests
 2
 3
 4
 5 from bs4 import BeautifulSoup
 6
 7 import bs4
 8
 9 import re
10
11
12
13 def getHTML_Text(url):
14
15         return ''
16
17
18
19 def Get_Catalog(ulist,url):
20
21     return ''
22
23
24
25 def Get_Content(ulist,url):
26
27     return ''
28
29
30
31 def Save_file(ulist):
32
33     return ''
34
35
36
37 def main():
38
39     url = 'http://www.biqiuge.com/book/'
40
41     catalog_url = []
42
43     Get_Catalog(catalog_url,url+'4772/')
44
45     for i in catalog_url:
46
47         str_temp = ''
48
49         Get_Content(str_temp,url+i)
50
51         Save_file(str_temp)
52
53
54
55 if __name__ == '__main__':
56
57     main()

  在main()函数中,首先是获取所有的url链接到我们的catalog_url列表中,然后用一个for循环迭代每一个url链接,然后对其爬取章节的内容,爬取完之后保存到txt文件中。

  其中getHTML_Text()已经用了很多遍了,直接套用前几期讲到的通用代码框架就好了,接下来我们看Get_Catalog()函数:

 1 def Get_Catalog(ulist,url):
 2
 3     html = getHTML_Text(url)
 4
 5     for i in re.findall(r'4772/\d+.html',html):
 6
 7         ulist.append(i)
 8
 9     for j in range(9):
10
11         del ulist[0]

  爬取到每个章节的专属url链接的部分之后,我们发现其实有多余重复的部分,就用del把前面8个url链接删除掉。

  我们一共获取了1049个url链接,我们来核对一下数量到底对不对,

  由82开始到1130结束,1130-82+1=1049,刚刚好获取到了每个章节特有的url链接,后面使用的时候只需要用字符串+就构造好我们需要的各个章节的url链接了。

  然而事情并不是想象中那么顺利。。。

  这个网站的服务器居然能识别出我这只小小爬虫了,我#!¥!%

  即使不是产生异常,那也只有小说里面的一句话作为返回,真的是气死老夫了!

  这时候要转移目标了,虽然很心痛,但是前面积累了经验,到后面就可以很快就用得上了,问题不大。(默默流泪,技术还是不过关,菜鸟一枚)不断失败,不断尝试,不断进步!

  我们重新搭建框架:

 1 import requests
 2
 3 import re
 4
 5
 6
 7 def getHTML_Text(url):
 8
 9     return ‘’
10
11 def Get_Catalog(ulist,url):
12
13 return ‘’
14
15 def Get_Content(str_temp,url):
16
17 return ‘’
18
19 def Save_file(f,str_temp):
20
21     return ‘’
22
23 def main():
24
25     url = 'http://www.liushuba.com/files/article/html/60/60255/'
26
27     catalog_url = []
28
29     Get_Catalog(catalog_url,url)
30
31
32
33     for i in catalog_url:
34
35             str_temp = ''
36
37             Get_Content(str_temp,url+i)
38
39
40
41 if __name__ == '__main__':
42
43     main()
44
45  

  这里我们用的是新网站,也就是上面代码的url链接,分析过程与笔趣阁网站的分析一样,这里就跳过了。

  getHTML_Text()函数仍然是通用的代码框架,而我们的Get_Catalog()函数就发生了改变,因为我们新找到的网站结构更简单了!

  看函数:

1 def Get_Catalog(ulist,url):
2
3     html = getHTML_Text(url)
4
5     for i in re.findall(r'\d+.html',html):
6
7         ulist.append(i)

用正则表达式\d+.html 就能直接找到所有的各个章节的url链接了!

接着就是获取每个章节的内容和保存本章节内容的函数了:

 1 def Get_Content(str_temp,url):
 2
 3 html = getHTML_Text(url)
 4
 5
 6
 7     for i in re.findall(u'[\u4e00-\u9fa5\(\)\《\》\——\;\,\。\:\“\”\!\?]+<br',html):
 8
 9         str_temp = str_temp+i[:-3]
10
11         str_temp = str_temp+'\n'
12
13
14
15     with open('圣墟.txt', 'a') as f:
16
17
18
19         Save_file(f,str_temp)
20
21
22
23 def Save_file(f,str_temp):
24
25     f.write(str_temp)

  这里我们用了一个比较复杂的正则表达式,简单来说就是匹配所有的中文文字和中文的一些常用标点符号,我们这里匹配的最后是以<br为特征的字符串,然后用字符串的截取功能,把最后的<br去掉,就可以得到每个章节的内容了,最后加上写文件的功能,用with结构,可以自动的调用文件对象的close()方法而不用我们手动去写了,注意这里我们是用’a’模式,就是在圣墟.txt这个文件后面继续添加内容。

  最后我爬取的小说内容大家可以看看:

  还有不足的地方就是我们这个还没有目录,于是我们把获取各章节的那个函数再改造一下,我们用BeautifulSoup的强大功能!

  根据网页中的html文本结构,很容易用BeautifulSoup把需要的信息提取出来。

 1 def Get_Catalog(ulist,url):
 2
 3     html = getHTML_Text(url)
 4
 5     soup = BeautifulSoup(html,'html.parser')
 6
 7     for td in soup('tbody'):
 8
 9         if isinstance(td,bs4.element.Tag):
10
11             for i in td('a'):
12
13                 if isinstance(i,bs4.element.Tag):
14
15                     ulist.append([i.get('href'),i.get('title')])

  我们把tbody中的所有的<a>标签用get()函数获取href和title的属性值,就是对应我们每个章节的专属url链接和章节名。

 1 def Get_Content(str_temp,url,title):
 2
 3     html = getHTML_Text(url)
 4
 5
 6
 7     str_temp = str_temp + title +'\n'
 8
 9     for i in re.findall(u'[\u4e00-\u9fa5\(\)\《\》\——\;\,\。\:\“\”\!\?]+<br',html):
10
11         str_temp = str_temp+i[:-3]
12
13         str_temp = str_temp+'\n'
14
15     with open('圣墟.txt', 'a') as f:
16
17         Save_file(f,str_temp)

  相应的保存到文件的时候也需要保持我们爬取的章节名!

  最后看看我们的成品结果:

  已经有了章节名字,哈哈哈,这个项目的效果就达到了,但是速度上还是有点慢,这个还需要优化一下,但总体上已经实现了我们想要的功能。

  本讲全代码:

  第一版(没有章节名)

 1 import requests
 2
 3 import re
 4
 5
 6
 7 def getHTML_Text(url):
 8
 9     try:
10
11         r = requests.get(url,timeout = 20)
12
13         r.raise_for_status() #如果状态不是200,则产生异常
14
15         r.encoding = r.apparent_encoding
16
17         return r.text
18
19     except:
20
21         return '产生异常'
22
23
24
25 def Get_Catalog(ulist,url):
26
27     html = getHTML_Text(url)
28
29     for i in re.findall(r'\d+.html',html):
30
31         ulist.append(i)
32
33 def Get_Content(str_temp,url):
34
35 html = getHTML_Text(url)
36
37
38
39     for i in re.findall(u'[\u4e00-\u9fa5\(\)\《\》\——\;\,\。\:\“\”\!\?]+<br',html):
40
41         str_temp = str_temp+i[:-3]
42
43         str_temp = str_temp+'\n'
44
45
46
47     with open('圣墟.txt', 'a') as f:
48
49
50
51         Save_file(f,str_temp)
52
53
54
55 def Save_file(f,str_temp):
56
57     f.write(str_temp)
58
59
60
61 def main():
62
63     url = 'http://www.liushuba.com/files/article/html/60/60255/'
64
65     catalog_url = []
66
67     Get_Catalog(catalog_url,url)
68
69
70
71     for i in catalog_url:
72
73             str_temp = ''
74
75             Get_Content(str_temp,url+i)
76
77
78
79 if __name__ == '__main__':
80
81 main()

  第二版(有章节名)

 1 import requests
 2
 3 from bs4 import BeautifulSoup
 4
 5 import bs4
 6
 7 import re
 8
 9
10
11 def getHTML_Text(url):
12
13     try:
14
15         r = requests.get(url,timeout = 20)
16
17         r.raise_for_status() #如果状态不是200,则产生异常
18
19         r.encoding = r.apparent_encoding
20
21         return r.text
22
23     except:
24
25         return '产生异常'
26
27
28
29
30
31 def Get_Catalog(ulist,url):
32
33     html = getHTML_Text(url)
34
35     soup = BeautifulSoup(html,'html.parser')
36
37     for td in soup('tbody'):
38
39         if isinstance(td,bs4.element.Tag):
40
41             for i in td('a'):
42
43                 if isinstance(i,bs4.element.Tag):
44
45                     ulist.append([i.get('href'),i.get('title')])
46
47
48
49 def Get_Content(str_temp,url,title):
50
51     html = getHTML_Text(url)
52
53
54
55     str_temp = str_temp + title +'\n'
56
57     for i in re.findall(u'[\u4e00-\u9fa5\(\)\《\》\——\;\,\。\:\“\”\!\?]+<br',html):
58
59         str_temp = str_temp+i[:-3]
60
61         str_temp = str_temp+'\n'
62
63     with open('圣墟.txt', 'a') as f:
64
65         Save_file(f,str_temp)
66
67
68
69 def Save_file(f,str_temp):
70
71     f.write(str_temp)
72
73
74
75 def main():
76
77     url = 'http://www.liushuba.com/files/article/html/60/60255/'
78
79     catalog_url = []
80
81     Get_Catalog(catalog_url,url)
82
83
84
85     for i in catalog_url:
86
87             str_temp = ''
88
89             Get_Content(str_temp,url+i[0],i[1])
90
91
92
93 if __name__ == '__main__':
94
95     main()

  本讲到此结束,也就标志着Python简单爬虫就到此结束了,我只是简单讲述了爬虫的一些代码运用和一些实战项目,还有爬虫的运行机理,希望对大家有帮助,谢谢观看。

转载于:https://www.cnblogs.com/shuaiqi-XCJ/p/9026756.html

Python简单爬虫第六蛋!(完结撒花)相关推荐

  1. python简单爬虫

    python简单爬虫某网站简历模板 from lxml import etree import requestsdef main():url = "https://sc.chinaz.com ...

  2. python简单爬虫 指定汉字的笔画动图下载

    python简单爬虫 指定汉字的笔画动图下载 分析过程 打开网址首页http://www.hanzi5.com 选择一个字,比如"虐" 查看该汉字动图地址 右键该汉字动图,选择在新 ...

  3. Python 简单爬虫下载小说txt

    Python 简单爬虫下载小说txt #第一次写爬虫代码 欢迎交流指正 我们范例爬取的对象是笔趣阁的<圣墟> (最近非常火的连载小说) ##为什么选择笔趣阁# 主要是因为笔趣阁的源代码没有 ...

  4. Mysql完结汇总篇(18万字送给你),完结撒花

    hello大家好,我是黎杜,上一篇写了关于Mysql的日志篇,有兴趣的可以看一看,距离上一次的写完了JVM的调优所有部分:如何啃下JVM这座大山,完结撒花(完结篇),这些词也写完了关于Mysql的所有 ...

  5. 产品经理基础-10运营平台端产品设计(完结~撒花~)

    10运营平台端产品设计 文章目录 10运营平台端产品设计 一. 运营平台端产品功能规划 二.平台端用户管理产品设计 1.用户列表 2.用户审核 三.平台端内容管理产品设计 1.内容审核 2.分类管理 ...

  6. python简单爬虫程序分析_[Python专题学习]-python开发简单爬虫

    掌握开发轻量级爬虫,这里的案例是不需要登录的静态网页抓取.涉及爬虫简介.简单爬虫架构.URL管理器.网页下载器(urllib2).网页解析器(BeautifulSoup) 一.爬虫简介以及爬虫的技术价 ...

  7. python简单爬虫课题_VS2019python爬虫入门

    VS2019新建python项目 在vs2019中添加python编译环境 创建python控制台应用程序项目 配置python环境 安装requests第三方库 管理程序包,执行安装requests ...

  8. 可爱的python下载_GitHub - palxiao/PythonWebSpider: 一个可爱的python简单爬虫

    Python网络爬虫 语言环境:Python2.7 运行爬虫入口开始爬取 output.html查看结果 简单py爬虫,修改入口及解析器改变规则 新增存入数据库操作 需要插件(MySql) 补充:(折 ...

  9. Python简单爬虫入门-爬取链家租房网上的租房信息

    .又到了毕业季,租房成为广大毕业生关注的话题,考虑到只用到广州的租房信息,所以只爬取广州各个地区的租房信息,下面是用Python3.4.4编写简单爬虫爬取租房网信息的代码: #coding:utf-8 ...

最新文章

  1. 1-1 机器学习和深度学习综述-paddle
  2. 解决overfitting的方法
  3. 风向2018 | AI 突围
  4. Redis单机版本框架
  5. 笔记本电脑截屏怎么截_电脑的截屏与录屏
  6. 【数学】Element Swapping
  7. 信息学奥赛一本通(1134:合法C标识符查)
  8. 五子棋python设计心得_python五子棋游戏的设计与实现
  9. 错误:Mixed Content: The page at ‘https://XXX’ was loaded over HTTPS, but requested an in...
  10. 【分享】学长的安利来了~~O(∩_∩)O
  11. VS2012写的程序在VS2010打开时显示当前版本不兼容
  12. 2020年度博客之星发榜了,第一次参加,第70名,感谢给我投票的老铁们,2021继续努力!
  13. 基于PHP+MySQL的网上图书店商城在线销售系统
  14. 快速消除Word文档中空格
  15. arm mali 天梯图_电视盒子CPU天梯图:原来这些处理器都在这个档位
  16. 自动驾驶|福特将在美国新建自动驾驶汽车工厂 计划未来两年投产
  17. 用 java eclipse画出一个圆形并且可以控制半径大小
  18. Excel 里筛选手机号码所属运营商
  19. opencv-python傅里叶变换以及逆变换
  20. 磨金石教育摄影技能干货分享|优秀作品欣赏—技巧十足的艺术摄影

热门文章

  1. 感谢关注(*^_^*)
  2. 为什么很多新人猎头都坚持不下去?
  3. Python用selenium实现自动登录账号,密码
  4. 单片机c语言编程 时钟加日历转换,基于52单片机电子时钟日历系统的设计
  5. 这个南方古镇靠什么解决城市排水难题
  6. 颜色传感器TCS230及颜色识别电路(转)
  7. springboot增加elasticsearch7.x
  8. pandas学习之练习题解读
  9. matlab中函数SOFM在神经网络方面的使用方法
  10. python kafka库选择_【linux】安装python依赖库confluent_kafka