selenium----爬虫框架应用

# selenium测试框架在爬虫中的应用:


# 网页中通过js渲染的数据,爬虫的解决办法:
# 1. 去静态源码中查找<script>var infolist = {'name':'123', }</script>
# 2. 抓包或者网络请求中,查看是否有类似与json的get请求,直接请求这个json的API拿到数据
# 3. 使用phantomjs/selenium进行访问动态页面,而静态页面仍然使用requests进行获取


# selenium框架本身提供了许多元素定位的方法,find_element_by_id()这些方法底层是用python语言实现的,提取速度上会慢一些。通常情况下,使用phantomjs/selenium也只是获取js渲染后的网页源代码,而网页中数据的提取,还可以使用xpath, css, re, bs4, etree等。


# selenium框架的元素定位
# geckodriver.exe: 是selenium用来打开火狐浏览器的驱动。需要将它和python.exe放在一起。
# chromedriver.exe: 是谷歌的

# 注意:不兼容会出现启动错误
# 1. geckodriver.exe的版本必须和火狐浏览器的版本兼容;
# 2. geckodriver.exe的版本必须和当前操作系统兼容;

import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 创建一个浏览器对象,会打开一个浏览器窗口
driver = webdriver.Firefox()
# driver = webdriver.Chrome()

driver.get( 'https://www.baidu.com')

kw = driver.find_element( by=By.CSS_SELECTOR, value= "#kw")
kw.send_keys( 'selenium')


# 通过id定位到输入框
# keyword = driver.find_element_by_id('kw')
# # <class 'selenium.webdriver.firefox.webelement.FirefoxWebElement'>
# print(type(keyword))
#
# # 在向输入框中输入内容之前,可以先将之前的旧内容清空
# keyword.clear()
#
# # 向输入框中输入内容send_keys
# keyword.send_keys('selenium')
#
# # 通过class定位到搜索按钮
# search_btn = driver.find_element_by_class_name('s_btn')
#
# # 点击search_btn
# search_btn.click()
#
# time.sleep(3)
#
# driver.find_element_by_css_selector('.result > h3 > a').click()

# 通过一个连接标签的文本内容定位标签
# driver.find_element_by_link_text('贴吧')

# driver.find_element_by_xpath('')

# 批量获取元素
# res = driver.find_elements_by_css_selector('.result')
# res = driver.find_elements(by=By.CSS_SELECTOR, value='.result')


# 获取js渲染后的网页源代码
print(driver.page_source)


time.sleep( 3)
# 休眠2秒,将浏览器driver对象退出
driver.close()


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值