python爬虫xpath提取数据_爬虫篇 | Python使用正则来爬取豆瓣图书数据

本文介绍了如何使用Python的正则表达式来抓取豆瓣图书数据,强调在数据抓取时,优先使用xpath,若不适用再考虑正则。通过实例展示了如何匹配和提取所需信息,并提供了完整代码示例。
摘要由CSDN通过智能技术生成

最近整理一个爬虫系列方面的文章,不管大家的基础如何,我从头开始整一个爬虫系列方面的文章,让大家循序渐进的学习爬虫,小白也没有学习障碍.

爬虫篇 | 不会这几个库,都不敢说我会Python爬虫

爬虫篇 | Python现学现用xpath爬取豆瓣音乐

爬虫篇 | Python最重要与重用的库Request

爬虫篇 | Python爬虫学前普及

基础篇 | Python基础部分

这两天有读者要我出一篇使用正则表达式来抓取数据,于是这篇献上

首先需要说明的是,在数据抓取的时候,优先使用xpath,如果xpath不行再考虑正则或者bs4, 因为xpath简单且高效!

概念性的东西这里就不说了,我们直接来实战,这里只简单说明一下,详细的需要自己去查一下资料!

要爬取的图书内容:

f8f4e024d5e85856e108cca68391bf13.png

爬取到的数据

c5e2f2acf631a8331012a87c4ea246b0.png

. 可以匹配除换行符外的字符
re* 表示匹配0个或多个表达式
re?匹配0个或多个由前面正则表达式定义的片段,非贪婪模式,且只匹配前一个

  1. 首先我们需要完全抓取,所以我们要使用re.findall方法,又因为数据全部在

中,需要只需要对这个里面数据处理

然后每一列来匹配 因为还需要向后匹配查找,所以需要添加.*? 匹配一次,非贪婪模式. 等等匹配到cover下面的目录,我们可以匹配到href,获取再匹配标题,但alt包含标题,所以这里直接来提取,

接着需要提取数据出来这里使用(.*?) 把数据提出来,这里有多个数据需要提取,然后用数组呈现出来05758502fdecf62bc6cde5263514f62d.png

完整代码

import requests
import re
import sys
reload(sys)
sys.setdefaultencoding('utf-8')

url = 'https://book.douban.com/'
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko)\
Chrome/55.0.2883.87 Safari/537.36'}
html = requests.get(url, headers=headers)
html.encoding = 'utf-8'
# 这里我只取了链接与标题
patter = re.compile('(.*?)', re.S)
titles = re.findall(patter, html.text)
for each in titles:
   print '书籍链接:{},书籍标题:{},---书籍作者:{}'.format(each[0], each[1],each[2].strip())

如果你觉得文章还不错,请大家点赞分享下。你的肯定是我最大的鼓励和支持。

【完】如果觉得有料,来个在看,让朋友知道你越来越优秀了

说句题外话,有不少人想加我微信,看我朋友圈的每日分享,我姑且放出来,但名额有限,先来先得。我的朋友圈不止有技术分享,更有我的日常感悟,还有我个人商业思维观点 速速扫码添加!

7fb58fec014570b6e9740494464dd7bb.png扫码添加,备注:公号铁粉

推荐阅读

 爬虫篇 | 不会这几个库,都不敢说我会Python爬虫

 爬虫篇 | Python现学现用xpath爬取豆瓣音乐

 爬虫篇 | Python最重要与重用的库Request

爬虫篇 | Python爬虫学前普及

基础篇 | Python基础部分

讲真,做Python一定不要只会一个方向!

54982219caa38f32717bb65e2e7cecb7.png

accaa87341adde9d56983aa0df0a0495.png 喜欢就在看吧
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值