经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
《最新出炉》系列入门篇-Python+Playwright自动化测试-56- 多文件上传 - 下篇 - 北京-宏哥
来源:cnblogs  作者:北京-宏哥  时间:2024/7/29 9:22:20  对本文有异议

1.简介

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

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

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

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

2.1上传文件语法

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

3.input控件上传多文件

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

3.1代码设计

3.2参考代码

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

3.3运行代码

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

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

4.非input控件上传多文件

4.1代码设计

4.2参考代码

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

    1. <input type="file" multiple>

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

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

原文链接:https://www.cnblogs.com/du-hong/p/18135908

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号