使用selenium爬虫抓取数据
写在前面本来这篇文章该几个月前写的,后来忙着忙着就给忘记了。 准备工具/原料1、java语言 步骤1、分解需求:
2、代码实现思路:
3、实例代码import org.junit.AfterClass; org.junit.BeforeClass; org.junit.Test; org.openqa.selenium.By; org.openqa.selenium.WebDriver; org.openqa.selenium.chrome.ChromeDriver; import java.awt.*; java.awt.event.KeyEvent; java.util.concurrent.TimeUnit; /** * @author rongrong * Selenium模拟访问网站爬虫操作代码示例 */ public class Demo { private static WebDriver driver; static final int MAX_TIMEOUT_IN_SECONDS = 5; @BeforeClass 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 void tearDownAfterClass() Exception { if (driver != null) { System.out.println("运行结束!"); driver.quit(); } } @Test void test() InterruptedException { Robot robot = ; try { robot = 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请求)相比,这可能会产生更多的流量。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Dojo mobile TweetView 系列教程之二 —— TweetView 启程
- winform中,使用openfileDialog而引起的“Unable to open th
- mfc和flash通讯:怎么设置flash组件的值
- Crawling Ajax-based Web Applications
- 正则表达式 – 如何从字符串中获取第2个和第4个字符
- 为什么要使用NoSQL
- c# – Windows窗体应用程序在夜间运行时随机冻结
- ruby-on-rails – 如何使用Ruby on Rails创建zip存档?
- ArcGIS Server FLEX API调用百度地图实现技术
- 如何使用Oracle中某个范围内的随机值更新表列?