本文实例讲述了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网页功能示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)