《最新出炉》系列入门篇-Python+Playwright自动化测试-56- 多文件上传 - 下篇

news/2024/11/15 4:48:12/文章来源:https://www.cnblogs.com/du-hong/p/18135908

1.简介

前边的两篇文章中,宏哥分别对input控件上传文件和非input控件上传文件进行了从理论到实践地讲解和介绍,但是后来又有人提出疑问,前边讲解和介绍的都是上传一个文件,如果上传多个文件,Playwright是如何实现的呢?宏哥看了一下官方的API也有上传多个文件的API,那么今天就来讲解和介绍一下这个知识点。

2.上传多文件的API(非input控件)

上传多文件介绍官方API的文档地址:Locator | Playwright Python

可以使用locator.set_input_files()方法选择要上传的输入文件。
它期望第一个参数指向类型为 的输入元素"file"。数组中可以传递多个文件。
如果某些文件路径是相对的,则它们将相对于当前工作目录进行解析。空数组清除所选文件。

2.1上传文件语法

# Select one file    选择一个文件
page.get_by_label("Upload file").set_input_files('myfile.pdf')# Select multiple files   选择多个文件
page.get_by_label("Upload files").set_input_files(['file1.txt', 'file2.txt'])# Remove all the selected files  移除所有文件
page.get_by_label("Upload file").set_input_files([])# Upload buffer from memory  从缓存中上传
page.get_by_label("Upload file").set_input_files(files=[{"name": "test.txt", "mimeType": "text/plain", "buffer": b"this is a test"}],
)

3.input控件上传多文件

宏哥找了一个线上的input上传多文件的例子,然后用代码实现一下。

3.1代码设计

3.2参考代码

# coding=utf-8🔥# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2024-04-21
@author: 北京-宏哥
公众号:北京宏哥(微信搜索:北京宏哥,关注宏哥,提前解锁更多测试干货!)
Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-56- 上传文件 - 番外篇
'''# 3.导入模块from playwright.sync_api import Playwright, sync_playwright, expect
def run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False)context = browser.new_context()page = context.new_page()page.goto("https://www.jq22.com/demo/jstpsc202005191001")# 定位选择文件按钮page.locator('#upload-input').set_input_files(['C:/Users/Administrator/Desktop/bjhg.jpg','C:/Users/Administrator/Desktop/hg.png'])#file_input_element.input_file('C:/Users/DELL/Desktop/bjhg.png')page.wait_for_timeout(10000)print("browser will be close")page.close()context.close()browser.close()
with sync_playwright() as playwright:run(playwright)

3.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(看可以看到宏哥上传的两张图片)。如下图所示:

4.非input控件上传多文件

4.1代码设计

4.2参考代码

# coding=utf-8🔥# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2024-04-21
@author: 北京-宏哥
公众号:北京宏哥(微信搜索:北京宏哥,关注宏哥,提前解锁更多测试干货!)
Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-56- 上传文件 - 番外篇
'''# 3.导入模块from playwright.sync_api import Playwright, sync_playwright, expect
def run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False)context = browser.new_context()page = context.new_page()page.goto("https://www.jq22.com/demo/easyUpload201801161800")with page.expect_file_chooser() as fc_info:page.locator('//*[@id="easy1"]/div[2]/div[1]').click()  # 点击选择文件按钮# page.pause()file_chooser = fc_info.valuefile_chooser.set_files(['C:/Users/Administrator/Desktop/bjhg.jpg','C:/Users/Administrator/Desktop/hg.png'])  # 上传文件page.wait_for_timeout(10000)print("browser will be close")page.close()context.close()browser.close()
with sync_playwright() as playwright:run(playwright)

4.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(看可以看到宏哥上传的两张图片)。如下图所示:

5.小结

5.1可能遇到的问题

1.上传多文件时,报错playwright._impl._api_types.Error: Error: Non-multiple file input can only accept single file  ,如下图所示:

报错原因:错误提示表明在尝试为一个不支持多文件上传的输入元素提供多个文件时发生了错误。通常,HTML的<input>元素如果type属性为file,并且没有设置multiple属性,那么它只能接受单个文件。这个涉及到前端的知识,宏哥在这里简单提一些,就不详细赘述了,有兴趣的小伙伴或者童鞋们可以自己查资料了解学习一下。

解决方法:

  1. 如果你的代码中确实需要上传多个文件,那么你需要确保输入元素能够接受多个文件。这通常意味着在HTML中设置multiple属性:

    <input type="file" multiple>

上传文件是我们经常需要面对的场景,如果我们使用的是selenium,那我们的操作会比较复杂,因为有的文件上传是input控件,有些是需要我们直接传文件地址,一旦弹出文件选择框的话,selenium就无能为力了,而playwright能很好地帮我们解决这个问题。

 好了,今天时间也不是很早了,宏哥今天就讲解和分享到这里,感谢您耐心的阅读。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/773460.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

7.28-8.11 中山集训

第一次外地集训欸主要放模拟赛,还有一些简短的记录。 7.29頑張って

GPU的体系结构几个演进

GPU的体系结构几个演进 从体系结构的视角看, GPU的诞生一开始是为了解决访存的问题, 1994年的时候整个图形渲染流水线基本上已经固定成为开放的OpenGL标准。伴随着GeForce 6的发布,Vertex Shader和Pixel Shader都支持了完整分支、循环、预测等功能实现,最终一个完全支持高级渲…

LInux 组合命令小结

cut -d: -f1 /etc/passwd #显示特定行ifconfig lo | grep "inet" | grep -v "inet6" |awk {print $2} #显示回环地址lo地址

一文汇总全球热门新闻API

新闻API通过提供快速、准确和全面的新闻内容,已经成为现代社会不可或缺的一部分,对人们的生活、工作环境和科技发展产生了深远的影响。新闻API使人们能够快速获取来自世界各地的实时新闻和信息,提高了信息的可访问性。通过新闻API,用户可以根据自己的兴趣和偏好接收定制化的…

读零信任网络:在不可信网络中构建安全系统03威胁模型

读零信任网络:在不可信网络中构建安全系统03威胁模型1. 信任管理 1.1. 信任源自于人,并通过计算机可以执行的信任机制流入其他系统 1.1.1. 只有使用系统的人确信它确实按照其意愿忠实地运行,该系统才能被认为是可信的 1.2. 信任管理是零信任…

Pinely Round 4 (Div. 1 + Div. 2)

离上紫一步之遥了这场打完又掉下去了哈哈真是太搞目录写在前面ABCDEF写在最后 写在前面 比赛地址:https://codeforces.com/contest/1991 离上紫一步之遥了这场打完又掉下去了哈哈真是太搞 A 签到。 对于每个位置检查两侧数的数量是否为奇数,若为奇数则无法删的只剩这个位置。…

基于 AnythingLLM 及 Ollama 构建本地知识库

基于 AnythingLLM 及 Ollama 构建本地知识库RAG Ollama AnythingLLM1. 什么是 RAG RAG(Retrieval Augmented Generation)检索增强生成,是 2023 年最火热的 LLM 应用系统架构,它的作用简单来说就是通过检索获取相关的知识并将其融入 Prompt,让大模型能够参考相应的知识从而…

LeetCode98. 验证二叉搜索树

题目链接:https://leetcode.cn/problems/validate-binary-search-tree/description/ 题目叙述: 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效二叉搜索树定义如下:节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。…

乒乓球比赛计分程序模拟冲刺(Sprint)计划

模拟冲刺(Sprint)计划选择的小用户故事:赵冠军(运动员)- 实时比分显示张赛事(赛事组织者)- 赛事信息录入王公正(裁判员)- 自动计分与记录一、任务拆分及开发时间(假设为网页版程序): 1. 赵冠军 - 实时比分显示 任务1:设计实时比分显示界面 开发时间:2天任务描述:…

一台个人pc电脑如何多开微信

之前在联想做技术支持,一直都是给客户一个附件文件来多开,今天教各位一个简单快捷的方法,工具的方法我也提供下,在文档结尾。 先用记事本编辑 start "" "C:\ProgramFiles\Tencent\WeChat\WeChat.exe"文件另存为bat后缀文件之后就是ctrl+c ctrl+v选中多…

结构体中vector的初始化报错:expected identifier before numeric constant

结构体中vector的初始化报错:expected identifier before numeric constant 结构体中vector初始化 起因: 我想在结构体中初始化含有3个元素的vector。报错: expected identifier before numeric constant,意思是数字常量前应该要有表示符。 原因: 编译器认为我正在定义一个…