用webdriver模仿浏览器 爬取豆瓣python书单

其中运用到os 模块 作用是生成文件夹 存储爬取的信息

etree 用于xpath解析内容 详细代码如下 可用我的上一篇博客存取到excel当中

import os
import time
from selenium import webdriver
from lxml import etree
#创建文件夹 没有指定的文件夹则创建 有则跳过
root_dir = 'douban/img'
if not os.path.exists(root_dir):
os.mkdir(root_dir) #生成浏览器对象
driver = webdriver.PhantomJS() #抓取页面函数
def spider(page):
base_url = 'https://book.douban.com/subject_search?search_text=python&cat=1001&start=%s'%(page*15)
#用浏览器的get获取上述网址的网页
driver.get(base_url)
#阻塞四秒 让页面完全显示出来
time.sleep(4)
#命名文件名称和存储文件路径
filename = root_dir + '/%s.png'%(page)
#截屏并保存 这只是图片 在指定路径查找看是否有图片
driver.save_screenshot(filename) #打印页面内容 可以打印出页面元素
# print(driver.page_source) #在解析函数中解析页面元素
content_parser(driver.page_source) #解析函数
def content_parser(content):
#我们这一次用xpath来解析 首先把上述内容生成树结构
tree = etree.HTML(content)
#在全部内容中 查找class为item-root的div 生成一个书列表
books = tree.xpath('//div[@class="item-root"]') #遍历列表 获取每本书的信息
for book in books:
#拿取书皮图片信息
book_src = book.xpath('./a/img/@src')
if book_src != []:
book_src = book_src[0] #书名
book_name = book.xpath('.//div[@class="title"]/a')
if book_name != []:
book_name = book_name[0].text #书籍详细信息链接href
book_href = book.xpath('.//div[@class="title"]/a/@href')
if book_href != []:
book_href = book_href[0] #评分
book_rating = book.xpath('.//span[@class="rating_nums"]')
if book_rating != []:
book_rating = book_rating[0].text #细节 作者什么的
book_detail = book.xpath('.//div[@class="meta abstract"]')
if book_detail != []:
book_detail = book_detail[0].text #打印需要一些时间 需要耐心等待哦
print(book_src,book_name,book_href,book_rating,book_detail) #主进程
if __name__ == '__main__':
#打印10个页面信息 每个页面信息15本书
for i in range(10):
spider(i)
'''
book:
<div class="item-root"> <a href="https://book.douban.com/subject/26829016/" data-moreurl="onclick=&quot;
moreurl(this,{i:'0',query:'python',subject_id:'26829016',from:'book_subject_search',
cat_id:'1001'})&quot;" class="cover-link">
<img src="https://img3.doubanio.com/lpic/s28891775.jpg"
alt="Python编程:从入门到实践 : 从入门到实践" class="cover" />
</a>
<div class="detail"> <div class="title">
<a href="https://book.douban.com/subject/26829016/" data-moreurl="onclick=&quot;
moreurl(this,{i:'0',query:'python',subject_id:'26829016',from:'book_subject_search',
cat_id:'1001'})&quot;" class="title-text">Python编程:从入门到实践 : 从入门到实践</a>
</div> <div class="rating sc-bwzfXH hxNRHc">
<span class="allstar45 rating-stars"></span>
<span class="rating_nums">9.0</span>
<span class="pl">(457人评价)</span>
</div> <div class="meta abstract">
[美]埃里克&middot;马瑟斯 / 袁国忠 / 人民邮电出版社 / 2016-7-1 / CNY 89.00
</div> <div class="meta abstract_2"></div> </div>
</div>
'''

用webdriver模仿浏览器 爬取豆瓣python书单的更多相关文章

  1. Python开发爬虫之静态网页抓取篇:爬取“豆瓣电影 Top 250”电影数据

    所谓静态页面是指纯粹的HTML格式的页面,这样的页面在浏览器中展示的内容都在HTML源码中. 目标:爬取豆瓣电影TOP250的所有电影名称,网址为:https://movie.douban.com/t ...

  2. 利用Python爬取豆瓣电影

    目标:使用Python爬取豆瓣电影并保存MongoDB数据库中 我们先来看一下通过浏览器的方式来筛选某些特定的电影: 我们把URL来复制出来分析分析: https://movie.douban.com ...

  3. python爬取豆瓣电影信息数据

    题外话+ 大家好啊,最近自己在做一个属于自己的博客网站(准备辞职回家养老了,明年再战)在家里 琐事也很多, 加上自己 一回到家就懒了(主要是家里冷啊! 广东十几度,老家几度,躲在被窝瑟瑟发抖,) 由于 ...

  4. python 爬取豆瓣电影短评并wordcloud生成词云图

    最近学到数据可视化到了词云图,正好学到爬虫,各种爬网站 [实验名称] 爬取豆瓣电影<千与千寻>的评论并生成词云 1. 利用爬虫获得电影评论的文本数据 2. 处理文本数据生成词云图 第一步, ...

  5. Python爬虫小白入门(七)爬取豆瓣音乐top250

      抓取目标: 豆瓣音乐top250的歌名.作者(专辑).评分和歌曲链接 使用工具: requests + lxml + xpath. 我认为这种工具组合是最适合初学者的,requests比pytho ...

  6. python定时器爬取豆瓣音乐Top榜歌名

    python定时器爬取豆瓣音乐Top榜歌名 作者:vpoet mail:vpoet_sir@163.com 注:这些小demo都是前段时间为了学python写的,现在贴出来纯粹是为了和大家分享一下 # ...

  7. Python爬取豆瓣音乐存储MongoDB数据库(Python爬虫实战1)

    1.  爬虫设计的技术 1)数据获取,通过http获取网站的数据,如urllib,urllib2,requests等模块: 2)数据提取,将web站点所获取的数据进行处理,获取所需要的数据,常使用的技 ...

  8. Python爬虫实例:爬取豆瓣Top250

    入门第一个爬虫一般都是爬这个,实在是太简单.用了 requests 和 bs4 库. 1.检查网页元素,提取所需要的信息并保存.这个用 bs4 就可以,前面的文章中已经有详细的用法阐述. 2.找到下一 ...

  9. Python爬取豆瓣指定书籍的短评

    Python爬取豆瓣指定书籍的短评 #!/usr/bin/python # coding=utf-8 import re import sys import time import random im ...

随机推荐

  1. Numpy Ndarray对象1

    标准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指 针.这样为了保存一个简单的[1,2,3],需要有3个指针和三 ...

  2. 2019牛客暑期多校训练营(第一场) - A - Equivalent Prefixes - 单调栈

    A - Equivalent Prefixes - 单调栈 题意:给定两个n个元素的数组a,b,它们的前p个元素构成的数组是"等价"的,求p的最大值."等价"的 ...

  3. 75.Binary Tree Maximum Path Sum(二叉树的最大路径和)

    Level:   Hard 题目描述: Given a non-empty binary tree, find the maximum path sum. For this problem, a pa ...

  4. CSS中的关系选择器

    关系选择器是指根据与其他元素的关系选择元素的选择器,常见的符号有空格.>.~,还 有+等,这些都是非常常用的选择器. 后代选择器:选择所有合乎规则的后代元素.空格连接. 相邻后代选择器:仅仅选择 ...

  5. parse_str()和http_build_query()的使用

    <?php $_html = array(); $_html['action1'] = 'action1'; $_html['action2'] = 'action2'; echo http_b ...

  6. ffmpeg音频文件转换之使用stdin/stdout或BytesIO对象输入输出

    最近在搞小程序录音,然后使用百度接口做语音识别. 小程序目前仅支持mp3和aac编码格式.虽然百度接口提供的m4a格式支持能直接识别小程序的录音文件,但由于自己还有其他一系列需求(比如直接读取数据,根 ...

  7. hadoop_hdfs_上传文件报错

    错误提示: INFO hdfs.DFSClient: Exception in createBlockOutputStream java.io.IOException: Bad connect ack ...

  8. Android】Retrofit网络请求参数注解,@Path、@Query、@QueryMap...(转)

    对Retrofit已经使用了一点时间了,是时候归纳一下各种网络请求的service了. 下面分为GET.POST.DELETE还有PUT的请求,说明@Path.@Query.@QueryMap.@Bo ...

  9. 二、Spring Boot系列:Spring Initializer快速创建Spring Boot项目

    1.点击创建新工程 2.选择Spring Initializer和jdk1.8 注意:项目名称要小写字母 3.现在只需要一个创建一个web,选择一个就好 4.没有用的文件,可以删除 5.pom.xml ...

  10. 第03章 AOP前奏

    第03章 AOP前奏 提出问题 ●情景:数学计算器 ●要求 ①执行加减乘除运算 ②日志:在程序执行期间追踪正在发生的活动 ③验证:希望计算器只能处理正数的运算 ●常规实现 ●问题 ○代码混乱:越来越多 ...