软件测试|使用selenium实现文件上传

在这里插入图片描述

简介

文件上传是我们web自动化测试工作中经常使用的场景,selenium同样也是支持我们实现自动化的文件上传操作,本文就来给大家介绍一下selenium如何实现自动化文件上传。

input标签文件上传

一般情况下,文件上传的按钮是一个<input>标签,并且附带的type属性为file,这样的标签我们可以使用send_keys()方法来实现文件上传。

页面代码如下:

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
</head>
<body>
<fieldset>
    <legend>文件上传</legend>
    <form action="">
        <input type="file" name="upfile" value="">
    </form>
</fieldset>
</fieldset>
</body>
</html>

我们实现文件上传的代码如下:

# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
from selenium.webdriver.common.by import By

# 2.打开浏览器


driver = webdriver.Chrome()

# 3.打开页面
url = "file:///" + os.path.abspath("test555.html")
driver.get(url)
sleep(2)

# 4.上传文件
# 4.1 定位上传文件按钮
upfile = driver.find_element(By.NAME, 'upfile')

# 4.2 使用send_keys方法上传文件
upfile.send_keys(r"C:\Users\...\Desktop\测试文件.txt")
sleep(5)

# 5.关闭浏览器
driver.quit()

非input标签文件上传

对于非input标签的文件上传控件,我们需要先找到该控件的元素。这通常需要查看目标网页的HTML结构,以确定控件的选择器。例如,可能是一个<div>元素或<button>元素,点击它将触发文件选择对话框。

页面代码如下:

<!DOCTYPE html>
<html lang="zh-cn">
<meta charset="UTF-8">
<body>
    <div id="file-upload">
        <button id="upload-button">上传文件</button>
    </div>
</body>
</html>

在这个示例中,我们有一个<div>元素,其中包含一个按钮,用于触发文件上传操作。实现文件上传的代码如下:

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys

# 设置WebDriver路径
driver = webdriver.Chrome(executable_path="path_to_chromedriver")

# 打开一个示例网页
driver.get("https://example.com")

# 找到上传按钮
upload_button = driver.find_element(By.ID,"upload-button")

# 点击上传按钮
upload_button.click()

# 模拟文件选择对话框
file_input = driver.switch_to.active_element
file_input.send_keys("path_to_your_file.txt")

# 提交文件
submit_button = driver.find_element(By.ID, "submit")
submit_button.click()

# 关闭浏览器
driver.quit()

在这个示例中,我们首先找到"上传文件"按钮,然后点击它。接下来,我们将焦点切换到当前活动的元素,这通常是文件选择对话框,然后使用send_keys方法发送文件的路径。最后,我们模拟点击提交按钮。

总结

本文主要介绍了使用selenium实现文件上传的步骤,对于input标签的文件上传,我们可以直接使用send_keys()来实现文件上传,对于非input标签的文件上传,我们可以使用Keys()操作来实现文件上传的操作,希望本文能帮助到大家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值