搜索
首页web前端js教程使用phantomjs进行网页抓取的实现代码_javascript技巧

phantomjs因为是无头浏览器可以跑js,所以同样可以跑dom节点,用来进行网页抓取是再好不过了。

比如我们要批量抓取网页 “历史上的今天” 的内容。网站

对dom结构的观察发现,我们只需要取到 .list li a的title值即可。因此我们利用高级选择器构建dom片段

var d= ''
var c = document.querySelectorAll('.list li a')
var l = c.length;
for(var i =0;i<l;i++){
d=d+c[i].title+'\n'
}

之后只需要让js代码在phantomjs里跑起来即可~

var page = require('webpage').create();
	page.open('http://www.todayonhistory.com/', function (status) { //打开页面
		if (status !== 'success') {
			console.log('FAIL to load the address');
		} else {
			console.log(page.evaluate(function () {
					var d= ''
					var c = document.querySelectorAll('.list li a')
					var l = c.length;
					for(var i =0;i<l;i++){
					d=d+c[i].title+'\n'
					}
						return d
				}))

		}
		phantom.exit();
	});

最终我们另存为catch.js,在dos里面执行一下,输出内容到txt文件(也可以用phantomjs的文件api来写)

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在Scrapy爬虫中使用Selenium和PhantomJS在Scrapy爬虫中使用Selenium和PhantomJSJun 22, 2023 pm 06:03 PM

在Scrapy爬虫中使用Selenium和PhantomJSScrapy是Python下的一个优秀的网络爬虫框架,已经被广泛应用于各个领域中的数据采集和处理。在爬虫的实现中,有时候需要模拟浏览器操作去获取某些网站呈现的内容,这时候就需要用到Selenium和PhantomJS。Selenium是模拟人类对浏览器的操作,让我们可以自动化地进行Web应用程序测试

PHP中如何使用PhantomJS进行无界面测试PHP中如何使用PhantomJS进行无界面测试Jun 27, 2023 am 09:27 AM

在现代Web开发的环境下,无界面测试是不可或缺的一个步骤,因为它可以模拟用户操作并且验证UI的正确性。PhantomJS是一个流行的工具,用于在无界面环境下进行自动化测试。本文将介绍如何使用PHP中的PhantomJS进行无界面测试。一、安装PhantomJS首先,需要在机器上安装PhantomJS,可以从官网下载并进行安装。以下是Linux下的安装步骤:下

如何使用Go语言中的并发函数实现多个网页的并行抓取?如何使用Go语言中的并发函数实现多个网页的并行抓取?Jul 29, 2023 pm 07:13 PM

如何使用Go语言中的并发函数实现多个网页的并行抓取?在现代Web开发中,经常需要从多个网页中抓取数据。一般的做法是逐个发起网络请求并等待响应,这样效率较低。而Go语言提供了强大的并发功能,可以通过并行抓取多个网页来提高效率。本文将介绍如何使用Go语言的并发函数实现多个网页的并行抓取,以及一些注意事项。首先,我们需要使用Go语言内置的go关键字创建并发任务。通

PHP如何进行网页抓取和数据爬取?PHP如何进行网页抓取和数据爬取?Jun 29, 2023 am 08:42 AM

PHP是一种服务器端脚本语言,广泛应用于网站开发和数据处理等领域。其中,网页抓取和数据爬取是PHP的一个重要应用场景之一。本文将介绍PHP如何进行网页抓取和数据爬取的基本原理和常用方法。一、网页抓取和数据爬取的原理网页抓取和数据爬取指的是通过程序自动访问网页,并从中获取所需的信息。其基本原理是通过HTTP协议获取目标网页的HTML源码,然后通过解析HTML源

在Python中的网页抓取和数据提取技术在Python中的网页抓取和数据提取技术Sep 16, 2023 pm 02:37 PM

Python已成为各种应用程序的首选编程语言,其多功能性延伸到了网络抓取领域。凭借其丰富的库和框架生态系统,Python提供了一个强大的工具包,用于从网站提取数据并释放有价值的见解。无论您是数据爱好者、研究人员还是行业专业人士,Python中的网络抓取都可以成为利用大量在线信息的宝贵技能。在本教程中,我们将深入研究网络抓取领域,并探索Python中可用于从网站提取数据的各种技术和工具。我们将揭示网络抓取的基础知识,了解围绕这种做法的合法性和道德考虑,并深入研究数据提取的实际方面。在本文的下一部分

如何使用Java中的PhantomJS实现HTML页面截图功能?如何使用Java中的PhantomJS实现HTML页面截图功能?Apr 24, 2023 am 11:37 AM

I.背景如何在小程序里面生成一张图,分享到朋友圈呢?目前前端貌似没有太好的解决方法,所以只能猥琐的由后端来支持掉,那么可以怎么玩?生成图片比较简单简单的场景,可以直接用jdk来支持掉,一般来讲也没有太复杂的逻辑之前写过一个图片合成的逻辑,利用awt实现:图片合成通用、复杂的模板简单的可以直接支持,但复杂一点的,让后端来支持,无疑比较恶心,在github上也搜索了一些渲染html的开源库,不知道是姿势不对还是咋的,没有太满意的结果现在对复杂的模板,要怎么支持呢?也就是本篇的指南,利用phantom

学习如何使用win10批量下载网页中的图片学习如何使用win10批量下载网页中的图片Jan 03, 2024 pm 02:04 PM

在使用win10下载图片视频的时候,单个的下载对于需要大批量下载图片的用户来说就很不方便了。那么win10怎么才能批量下载网页中图片。现在让小编来告诉你。希望可以帮助到你。win10怎么批量下载网页中图片1、首先要在电脑上安装迅雷,2、打开电脑,打开自带的Edge浏览器。在输入框输入查找的关键词,然后百度一下3、点击,如下图所示,4、在新界面,点击右上角的三个小点的图标,然后选择,IE是电脑本身就带有的,无需安装,5、在跳转到的IE界面,鼠标右键单击日益空白处,选择6、在迅雷下载界面,在顶部点击

Java中怎么用PhantomJs完成html图片输出功能Java中怎么用PhantomJs完成html图片输出功能May 12, 2023 am 08:55 AM

I.背景如何在小程序里面生成一张图,分享到朋友圈呢?目前前端貌似没有太好的解决方法,所以只能猥琐的由后端来支持掉,那么可以怎么玩?生成图片比较简单简单的场景,可以直接用jdk来支持掉,一般来讲也没有太复杂的逻辑之前写过一个图片合成的逻辑,利用awt实现:图片合成通用、复杂的模板简单的可以直接支持,但复杂一点的,让后端来支持,无疑比较恶心,在github上也搜索了一些渲染html的开源库,不知道是姿势不对还是咋的,没有太满意的结果现在对复杂的模板,要怎么支持呢?也就是本篇的指南,利用phantom

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中