简单的自动化场景(以 Chrome 浏览器 为例)

1. 准备测试脚本

以下是一个完整的 Python 示例脚本,功能是 打开 Chrome 浏览器,访问百度并搜索关键词

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

# 1. 初始化 Chrome 浏览器驱动
driver = webdriver.Chrome()  # 确保 chromedriver 已加入 PATH,或指定路径:webdriver.Chrome(executable_path="chromedriver路径")

# 2. 打开百度首页
driver.get("https://www.baidu.com")
print("已打开百度首页")

# 3. 定位搜索框并输入关键词
search_box = driver.find_element(By.ID, "kw")  # 百度搜索框的HTML ID是"kw"
search_box.send_keys("Selenium自动化测试")
print("已输入搜索关键词")

# 4. 模拟按下回车键
search_box.send_keys(Keys.RETURN)
print("已触发搜索")

# 5. 等待3秒查看结果
time.sleep(3)

# 6. 关闭浏览器
driver.quit()
print("测试完成,浏览器已关闭")
复制代码
 

2. 运行步骤

  1. 确保环境正确

    • Chrome 浏览器已安装(如版本 109)。

    • chromedriver 版本与 Chrome 匹配(参考之前回答的版本建议)。

    • 脚本保存为 .py 文件(如 test_baidu.py)。

  2. 执行脚本

    python 复制代码
    python test_baidu.py
    复制代码
     
  3. 预期结果

    • 自动打开 Chrome 浏览器,访问百度。

    • 输入关键词并搜索,停留3秒后关闭。


3. 关键点说明

(1) 元素定位方式

  • By.ID:通过 HTML 元素的 id 属性定位(如百度搜索框的 id="kw")。

  • 其他常用定位方式:

    python 复制代码
    driver.find_element(By.NAME, "wd")          # 通过 name 属性
    driver.find_element(By.CLASS_NAME, "s_ipt") # 通过 class 属性
    driver.find_element(By.XPATH, "//input[@id='kw']") # 通过 XPATH

(2) 常见操作

  • 输入文本element.send_keys("文本")

  • 点击按钮element.click()

  • 模拟按键send_keys(Keys.RETURN)(回车键)

(3) 等待机制

  • 强制等待time.sleep(3)(简单但不推荐长期使用)。

  • 隐式等待(全局生效):

    python 复制代码
    driver.implicitly_wait(10)  # 最多等待10秒
    复制代码
     
  • 显式等待(推荐):

    python 复制代码
    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.support import expected_conditions as EC
    
    element = WebDriverWait(driver, 10).until(
        EC.presence_of_element_located((By.ID, "kw"))

4. 可能遇到的问题及解决

问题1:WebDriverException: Message: 'chromedriver' executable needs to be in PATH

  • 原因 :未正确配置 chromedriver 路径。

  • 解决

    • chromedriver.exe 放到 Python 安装目录的 Scripts 文件夹中。

    • 或在代码中指定路径:

      python 复制代码
      driver = webdriver.Chrome(executable_path="C:/path/to/chromedriver.exe")

问题2:浏览器闪退

  • 原因 :脚本结束后未调用 driver.quit()

  • 解决 :确保最后调用 driver.quit() 释放资源。

问题3:元素找不到(NoSuchElementException

  • 原因:页面未加载完或定位方式错误。

  • 解决

    • 添加等待(如显式等待)。

    • 检查元素属性是否动态变化(用浏览器开发者工具确认)。


5. 扩展场景

示例:登录网站并截图

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

driver = webdriver.Chrome()
driver.get("https://example.com/login")

# 输入用户名密码
driver.find_element(By.ID, "username").send_keys("testuser")
driver.find_element(By.ID, "password").send_keys("password123")

# 点击登录按钮
driver.find_element(By.XPATH, "//button[@type='submit']").click()

# 截图保存
driver.save_screenshot("login_success.png")
driver.quit()
复制代码
 

总结

  1. 基础流程:启动浏览器 → 定位元素 → 操作 → 关闭。

  2. 核心技巧:合理使用等待、多种定位方式和异常处理。

  3. 调试工具:浏览器开发者工具(F12)检查元素属性。

相关推荐
kadog13 分钟前
《Python3网络爬虫开发实战(第二版)》配套案例 spa6
开发语言·javascript·爬虫·python
徒慕风流14 分钟前
利用Python爬虫实现百度图片搜索的PNG图片下载
开发语言·爬虫·python
蹦蹦跳跳真可爱58923 分钟前
Python----深度学习(基于深度学习Pytroch线性回归和曲线回归)
pytorch·python·深度学习·神经网络·回归·线性回归
HtwHUAT41 分钟前
五、web自动化测试01
前端·css·chrome·python·功能测试·selenium·html
数巨小码人1 小时前
Linux常用指令
linux·运维·服务器
啊阿狸不会拉杆1 小时前
数据结构-图
java·c语言·数据结构·c++·python·算法·图论
哈哈幸运1 小时前
Linux Awk 深度解析:10个生产级自动化与云原生场景
linux·云原生·自动化·awk·三剑客
萧鼎1 小时前
RAGFlow:构建高效检索增强生成流程的技术解析
人工智能·python
Linux运维老纪1 小时前
Linux之七大难命令(The Seven Difficult Commands of Linux)
linux·运维·服务器·云计算·运维开发
cooljser2 小时前
告别手动操作!用脚本搞定小程序签到的全过程
python