利用selenium爬虫抓取数据的基础教程


Posted in Python onJune 10, 2019

写在前面

本来这篇文章该几个月前写的,后来忙着忙着就给忘记了。

ps:事多有时候反倒会耽误事。

几个月前,记得群里一朋友说想用selenium去爬数据,关于爬数据,一般是模拟访问某些固定网站,将自己关注的信息进行爬取,然后再将爬出的数据进行处理。

他的需求是将文章直接导入到富文本编辑器去发布,其实这也是爬虫中的一种。

其实这也并不难,就是UI自动化的过程,下面让我们开始吧。

准备工具/原料

1、java语言

2、IDEA开发工具

3、jdk1.8

4、selenium-server-standalone(3.0以上版本)

步骤

1、分解需求:

需求重点主要是要保证原文格式样式都保留:

将要爬取文章,全选并复制

将复制后的文本,粘贴到富文本编辑器中即可

2、代码实现思路:

键盘事件模拟CTRL+A全选

键盘事件模拟CTRL+C复制

键盘事件模拟CTRL+V粘贴

3、实例代码

import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;

import java.awt.*;
import java.awt.event.KeyEvent;
import java.util.concurrent.TimeUnit;

/**
 * @author rongrong
 * Selenium模拟访问网站爬虫操作代码示例
 */
public class Demo {
 private static WebDriver driver;
 static final int MAX_TIMEOUT_IN_SECONDS = 5;

 @BeforeClass
 public static void setUpBeforeClass() throws Exception {
  driver = new ChromeDriver();
  String url = "https://temai.snssdk.com/article/feed/index?id=6675245569071383053&subscribe=5501679303&source_type=28&content_type=1&create_user_id=34013&adid=__AID__&tt_group_id=6675245569071383053";
  driver.manage().window().maximize();
  driver.manage().timeouts().implicitlyWait(MAX_TIMEOUT_IN_SECONDS, TimeUnit.SECONDS);
  driver.get(url);
 }

 @AfterClass
 public static void tearDownAfterClass() throws Exception {
  if (driver != null) {
   System.out.println("运行结束!");
   driver.quit();
  }
 }

 @Test
 public void test() throws InterruptedException {
  Robot robot = null;
  try {
   robot = new Robot();
  } catch (AWTException e1) {
   e1.printStackTrace();
  }
  robot.keyPress(KeyEvent.VK_CONTROL);
  robot.keyPress(KeyEvent.VK_A);
  robot.keyRelease(KeyEvent.VK_A);
  Thread.sleep(2000);
  robot.keyPress(KeyEvent.VK_C);
  robot.keyRelease(KeyEvent.VK_C);
  robot.keyRelease(KeyEvent.VK_CONTROL);
  driver.get("https://ueditor.baidu.com/website/onlinedemo.html");
  Thread.sleep(2000);
  driver.switchTo().frame(0);
  driver.findElement(By.tagName("body")).click();
  robot.keyPress(KeyEvent.VK_CONTROL);
  robot.keyPress(KeyEvent.VK_V);
  robot.keyRelease(KeyEvent.VK_V);
  robot.keyRelease(KeyEvent.VK_CONTROL);
  Thread.sleep(2000);
 }
}

写在后面

笔者并不是特别建议使用selenium做爬虫,原因如下:

速度慢:

每次运行爬虫都要打开一个浏览器,初始化还需要加载图片、JS渲染等等一大堆东西;

占用资源太多:

有人说,把换成无头浏览器,原理都是一样的,都是打开浏览器,而且很多网站会验证参数,如果对方看到你恶意请求访问,会办了你的请求,然后你又要考虑更换请求头的事情,事情复杂程度不知道多了多少,还得去改代码,麻烦死了。

对网络的要求会更高:

加载了很多可能对您没有价值的补充文件(如css,js和图像文件)。 与真正需要的资源(使用单独的HTTP请求)相比,这可能会产生更多的流量。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python中的对象拷贝示例 python引用传递
Jan 23 Python
理解python多线程(python多线程简明教程)
Jun 09 Python
python用来获得图片exif信息的库实例分析
Mar 16 Python
简单解决Python文件中文编码问题
Nov 22 Python
pycharm修改界面主题颜色的方法
Jan 17 Python
查看python安装路径及pip安装的包列表及路径
Apr 03 Python
python二维码操作:对QRCode和MyQR入门详解
Jun 24 Python
matplotlib绘制多个子图(subplot)的方法
Dec 03 Python
Django 解决新建表删除后无法重新创建等问题
May 21 Python
Python库安装速度过慢解决方案
Jul 14 Python
python通过函数名调用函数的几种场景
Sep 23 Python
pytorch 实现变分自动编码器的操作
May 24 Python
Python 监测文件是否更新的方法
Jun 10 #Python
python实现随机漫步方法和原理
Jun 10 #Python
使用python判断jpeg图片的完整性实例
Jun 10 #Python
关于Python作用域自学总结
Jun 10 #Python
Python读写文件基础知识点
Jun 10 #Python
python django框架中使用FastDFS分布式文件系统的安装方法
Jun 10 #Python
python三大神器之fabric使用教程
Jun 10 #Python
You might like
Zend引擎的发展 [15]
2006/10/09 PHP
模仿OSO的论坛(二)
2006/10/09 PHP
php下获取http状态的实现代码
2014/05/09 PHP
php正则提取html图片(img)src地址与任意属性的方法
2017/02/08 PHP
php strftime函数获取日期时间(switch用法)
2018/05/16 PHP
关于javascript document.createDocumentFragment()
2009/04/04 Javascript
用jQuery toggleClass 实现鼠标移上变色
2014/05/14 Javascript
什么是Node.js?Node.js详细介绍
2014/06/01 Javascript
jquery操作select方法汇总
2015/02/05 Javascript
jQuery获得包含margin的outerWidth和outerHeight的方法
2015/03/25 Javascript
Node.js编程中客户端Session的使用详解
2015/06/23 Javascript
Bootstrap实现登录校验表单(带验证码)
2016/06/23 Javascript
JavaScript导航脚本判断当前导航
2016/07/12 Javascript
windows下vue-cli及webpack搭建安装环境
2017/04/25 Javascript
three.js加载obj模型的实例代码
2017/11/10 Javascript
基于Node.js实现压缩和解压缩的方法
2018/02/13 Javascript
layui实现form表单同时提交数据和文件的代码
2019/10/25 Javascript
微信小程序整个页面的自动适应布局的实现
2020/07/12 Javascript
Python利用operator模块实现对象的多级排序详解
2017/05/09 Python
django 常用orm操作详解
2017/09/13 Python
Python多线程中阻塞(join)与锁(Lock)使用误区解析
2018/04/27 Python
django 通过url实现简单的权限控制的例子
2019/08/16 Python
python机器学习实现决策树
2019/11/11 Python
python代码实现TSNE降维数据可视化教程
2020/02/28 Python
pytorch实现查看当前学习率
2020/06/24 Python
Python3+RIDE+RobotFramework自动化测试框架搭建过程详解
2020/09/23 Python
亚马逊印度站:Amazon.in
2017/10/15 全球购物
销售工作人员的自我评价分享
2013/11/10 职场文书
大学生四年生活自我鉴定
2013/11/21 职场文书
单位委托书怎么写
2014/09/21 职场文书
群众路线查摆问题及整改措施
2014/10/10 职场文书
服务员态度差检讨书
2014/10/28 职场文书
先进基层党组织事迹材料
2014/12/25 职场文书
教育实习指导教师评语
2014/12/31 职场文书
八年级历史教学反思
2016/02/19 职场文书
八年级作文之感恩
2019/11/22 职场文书