一文入门Python + Selenium动态爬虫——从了解房价开始

欢迎关注天善智能,我们是专注于商业智能BI,人工智能AI,大数据分析与挖掘领域的垂直社区,学习,问答、求职一站式搞定!

对商业智能BI、大数据分析挖掘、机器学习,python,R等数据领域感兴趣的同学加微信:tstoutiao,邀请你进入数据爱好者交流群,数据爱好者们都在这儿。

作者:timber ,在一家电子商务(外贸)公司任职运维,平常工作时我觉得敲命令的样子也很帅    ---Python,Changed me!

个人博客地址: 

https://blog.csdn.net/weixin_42946604

本文首发于:

https://blog.csdn.net/weixin_42946604

3901436-57a728fbdfc0aeb2
3901436-22400d741b9577d4

前言

我这里用到了的python+selenium来抓取链家房数据,因爲很多时候分析参数,头疼啊,能分析的还好。有些网页就很变态哦,参数都是经过加密的。

selenium自动化优点(我去找了一下度娘…哈哈),完全可以模拟人工操作网页,而且相对其他爬虫不用写请求头(偷懒),例如直接request的,听说更容易被封(403),我只是听说!

最后希望更大家互勉互力,一同进步!现在跟大家分享一下python selenium的小知识…

3901436-0496d0fe29b1b7a1
3901436-82c0e69638e6e592

整体流程

1、安裝selenium

命令行:pip install selenium 敲回车

3901436-448b71af077cc9fa

2、下載chromedriver插件,對應自己的版本,链接在此:

http://chromedriver.storage.googleapis.com/index.html

3901436-b56764373547d696

直接放在Python的Scripts目录下就可以不能配置变量了,而且也不用声明路径

(后面会说到)

3、安裝pyquery 一样的用到pip安装 敲回车

3901436-c74d90ff85ebe4ec

命令行:pip install pyquery

4、安裝pymysql

命令行:pip install pymysql 同上

3901436-b4fce5cd1f354a00

5、以上安裝完成后,开始我們的骚操作了。

3901436-b93a65e7bf5f1214
3901436-6e9b32d528638307

网页分析

一文入门Python + Selenium动态爬虫——从了解房价开始_第1张图片

我们不用声明请求头还有分析一些参数了,只要我们拿到URL,指哪爬哪!

此次抓取的数据如下:

一文入门Python + Selenium动态爬虫——从了解房价开始_第2张图片

那这些数据的提取正题就来了!

打开开发者工具,google浏览器直接挫F12

一文入门Python + Selenium动态爬虫——从了解房价开始_第3张图片

发现每个小区的售房信息都在ul下的li标签里面。直接上代码

一文入门Python + Selenium动态爬虫——从了解房价开始_第4张图片

第一步拿到html结构,然后用pyquery解析遍历li标签,我使用了items()方法

提取小区名称,找到a标签的class

3901436-d9ff1f79e075a9b3

提取房类的文本,span标签下面

3901436-60a5cabaefb2dff5

其他的TEXT文本都是这样的方法提取

提醒的一点就是

一文入门Python + Selenium动态爬虫——从了解房价开始_第5张图片

我们这里判断一下ul的class,防止有时候网络加载的问题,导致发生错误。

3901436-12ebbd61a03c2b14
3901436-ed541d7cbf181dae

模拟滚动,点击下一步操作

我们没跳转一页就滚动一下滚动条,这个有好处的哦有时候很多异步加载的,例如一下ajax加载的就是很好的例子了,查看评论的时候很多是这样的!我们来看一下

一文入门Python + Selenium动态爬虫——从了解房价开始_第6张图片

这也是个方法,根据个人不同来定义,我这里以800来滚动。

然后就是点击下一页的动作,网页有下一页的

一文入门Python + Selenium动态爬虫——从了解房价开始_第7张图片

代码实现 直接上图

3901436-37bfe2e22745687c

一些其他的小动作,可以自己添加哦!

3901436-f3bdedd15d038730
3901436-88791db8938a9ed7

数据存储

我这里用mysql存放数据,上图

一文入门Python + Selenium动态爬虫——从了解房价开始_第8张图片

我提前把数据表建好了的,表名为lianjie_data,数据库名是lianjie,这里根据个人情况。

你可以写一个data_save的方法,我这里简单粗暴点从上到下直接写完了。

好了运行程序

3901436-1337502acaa5a76d
3901436-a1778eb2275cfe49

数据展示

一文入门Python + Selenium动态爬虫——从了解房价开始_第9张图片

是不是完完全全模拟人工操作呢,其实我没加太多动作 嘻嘻

源码后续放出来,也会写一些更多的小知识更大家分享

一文入门Python + Selenium动态爬虫——从了解房价开始_第10张图片

千山万水总是情,点个「好看」行不行。

Python的爱好者社区历史文章大合集

2018年Python爱好者社区历史文章合集(作者篇)

福利:文末扫码关注公众号,“Python爱好者社区”,开始学习Python课程:

3901436-9fd34857eecfc0ba

关注后在公众号内回复“ 课程 ”即可获取:

小编的转行入职数据科学(数据分析挖掘/机器学习方向)【最新免费】

小编的Python的入门免费视频课程

小编的Python的快速上手matplotlib可视化库!

崔老师爬虫实战案例免费学习视频。

陈老师数据分析报告扩展制作免费学习视频。

玩转大数据分析!Spark2.X + Python精华实战课程免费学习视频。

一文入门Python + Selenium动态爬虫——从了解房价开始_第11张图片

你可能感兴趣的:(一文入门Python + Selenium动态爬虫——从了解房价开始)