Python3实现抓取javascript动态生成的html网页功能示例

Python3实现抓取javascript动态生成的html网页功能示例,第1张

概述本文实例讲述了Python3实现抓取javascript动态生成的html网页功能。分享给大家供大家参考,具体如下:

本文实例讲述了python3实现抓取JavaScript动态生成的HTML网页功能。分享给大家供大家参考,具体如下:

用urllib等抓取网页,只能读取网页的静态源文件,而抓不到由JavaScript生成的内容。

究其原因,是因为urllib是瞬时抓取,它不会等JavaScript的加载延迟,所以页面中由JavaScript生成的内容,urllib读取不到。

那由JavaScript生成的内容就真的没有办法读取了吗?非也!

这里要介绍一个python库:selenium,本文使用的版本是 2.44.0

先安装:

pip install -U selenium

下面用三个例子来说明其用法:

【例0】

打开一个firefox浏览器
载入所给URL地址的页面

from selenium import webdriverbrowser = webdriver.firefox()browser.get('http://www.baIDu.com/')

【例1】

打开一个firefox浏览器
载入百度主页
搜索 “seleniumhq”
关闭浏览器

from selenium import webdriverfrom selenium.webdriver.common.keys import Keysbrowser = webdriver.firefox()browser.get('http://www.baIDu.com')assert '百度' in browser.Titleelem = browser.find_element_by_name('p') # Find the search Boxelem.send_keys('seleniumhq' + Keys.RETURN) # 模拟按键browser.quit()

【例2】

Selenium WebDriver 常用于网络程序的测试。 下面是一个使用Python标准库 unittest 的例子:

import unittestclass BaIDuTestCase(unittest.TestCase):  def setUp(self):    self.browser = webdriver.firefox()    self.addCleanup(self.browser.quit)  def testPageTitle(self):    self.browser.get('http://www.baIDu.com')    self.assertIn('百度',self.browser.Title)if __name__ == '__main__':  unittest.main(verbosity=2)

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python进程与线程 *** 作技巧总结》、《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串 *** 作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录 *** 作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

总结

以上是内存溢出为你收集整理的Python3实现抓取javascript动态生成的html网页功能示例全部内容,希望文章能够帮你解决Python3实现抓取javascript动态生成的html网页功能示例所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1201697.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存