selenium使用

浏览器操作(方法)

1.maximize window()最大化浏览器

2.set window_size(width,height)设置浏览器宽、高(像素点)

3.set _window_position(x,y)设置浏览器位置,浏览器左上角相对于屏幕左上角位置

4.back()后退

5.forward()前进

6.refresh()刷新

7.close()关闭当前页面

8.quit()关闭浏览器

浏览器信息(属性)

  1. title 获取页面title

2.current url 获取当前页面URL

复制代码
from selenium import webdriver
from selenium.webdriver.common.by import By
import time

#创建webdriver对象,把驱动放置到了系统环境变量中,可不带参数创建
# driver =webdriver.Firefox()
driver = webdriver.Chrome()
#使用浏览器打开指定页面
driver.get('http://www.baidu.com')
#最大化浏览器
driver.maximize_window()

#定位元素
driver.find_element(By.ID, 'kw').send_keys("书包")
driver.find_element(By.ID, 'su').click()
print(driver.title)
print(driver.current_url)
time.sleep(3)
#浏览器后退
driver.back()
time.sleep(3)
#浏览器前进
driver.forward()
time.sleep(5)
#定位链接
# driver.find_element(By.LINK_TEXT,'hao123').click()

#xpath定位方法
# driver.find_element(By.XPATH,"//*[@aria-label='百度热搜']").click()
# driver.find_element(By.XPATH,"//input[@placeholder='请输入用户名']").send_keys("admin")
time.sleep(5)
#回收资源,关闭浏览器
driver.quit()

等待

为什么要等待

因为在web中看到的元素,不一定是写在html代码中的,有可能是通过javascript代码的dom操作产生出来的。 而js产生元素,很可能先要去获取到数据,处理后再去显示的。所以:不一定网页打开,所有的元素都在页面中了。 如果马上去找,可能出错。

强制等待,通过time.sleep()进行强制等待,通过自行判断等待时间,容易造成时间不准确,浪费时间或在时间太短导致出错。

1.显式等待

·如何操作

1.使用WebDriverWait包装 webDriver对象

2.使用 webDriverWait的util 方法,传入可调用对象(通常是presence of element located函数的返回值)

不推荐用,敲的代码太长

复制代码
from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException, TimeoutException
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
import time
# 启动Chrome WebDriver
driver = webdriver.Chrome()

# 设置隐式等待时间为10秒(通常只需要设置一次)
driver.implicitly_wait(10)

# 打开网页
driver.get('http://www.baidu.com')

try:
    # 查找并操作搜索框
    search_box = driver.find_element(By.ID, 'kw')
    search_box.send_keys("书包")
    search_button = driver.find_element(By.ID, 'su').click()

    # 使用显式等待等待搜索结果中的某个元素变得可点击(这里需要您根据实际情况修改)
    try:
        # 假设我们要点击第一个搜索结果(这只是一个示例,实际情况可能不同)
        first_result = WebDriverWait(driver, 10).until(
            EC.element_to_be_clickable((By.ID, '3001'))
        )
        first_result.click()  
    except TimeoutException:
        print("搜索结果加载超时")

except NoSuchElementException:
    print("搜索框或搜索按钮未找到")
finally:
    # 关闭浏览器
    time.sleep(5)
    driver.quit()

隐式等待

隐式的整不出来,不生效

复制代码
# 设置隐式等待时间为10秒
driver.implicitly_wait(10)
  1. 全局性:隐式等待一旦设置,在整个WebDriver会话中都生效。这意味着在该会话中查找的所有元素都会应用这个等待时间。
  2. 等待机制:隐式等待并不是让线程休眠一段时间,而是在规定的时间内不断刷新页面以查找元素。如果找到了元素,则立即返回;如果超时仍未找到,则抛出异常。
  3. 性能影响:虽然隐式等待简化了代码,但如果设置的等待时间过长,可能会影响测试脚本的执行性能。因此,应根据实际情况合理设置等待时间。
  4. 异常处理 :如果设置了隐式等待但仍然在查找元素时抛出了NoSuchElementException异常,这通常意味着元素确实不存在于页面上,或者定位方式有误。
相关推荐
記億揺晃着的那天2 小时前
Vue + Element UI 表格自适应高度如何做?
javascript·vue.js·ui
GISer_Jing3 小时前
ByteDance——jy真题
前端·javascript·面试
真的想不出名儿3 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
阳光阴郁大boy3 小时前
星座运势网站技术解析:从零打造现代化Web应用
前端·javascript
sorryhc4 小时前
如何设计一个架构良好的前端请求库?
前端·javascript·架构
Queen_sy4 小时前
vue3 el-date-picker 日期选择器校验规则-选择日期范围不能超过七天
javascript·vue.js·elementui
lvchaoq4 小时前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js
郝开4 小时前
6. React useState基础使用:useState修改状态的规则;useState修改对象状态的规则
前端·javascript·react.js
ANYOLY5 小时前
JVM 线上调优与排查指南
jvm·测试工具
技术钱6 小时前
react+andDesign+vite+ts从零搭建后台管理系统(三)-Layout布局
javascript·react.js·ecmascript