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异常,这通常意味着元素确实不存在于页面上,或者定位方式有误。
相关推荐
I'm Jie28 分钟前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324602 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
PPPPickup3 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫3 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
脾气有点小暴4 小时前
前端页面跳转的核心区别与实战指南
开发语言·前端·javascript
测试人社区-千羽4 小时前
大语言模型在软件测试中的应用与挑战
人工智能·测试工具·语言模型·自然语言处理·面试·职场和发展·aigc
San30.4 小时前
深入 JavaScript 内存机制:从栈与堆到闭包的底层原理
开发语言·javascript·udp
Fantastic_sj5 小时前
Vue3相比Vue2的改进之处
前端·javascript·vue.js
ttod_qzstudio6 小时前
深入理解 TypeScript 数组的 find 与 filter 方法:精准查找的艺术
javascript·typescript·filter·find
冬男zdn7 小时前
优雅处理数组的几个实用方法
前端·javascript