python playwright 库上传和下载操作(自动化测试 playwright)

 更新时间:2023年05月17日 09:33:19   作者:番茄牛腩不吃番茄  
这篇文章主要介绍了python playwright 库上传和下载操作(自动化测试 playwright ),playwright中的上传和下载比selenium的上传和下载要简便些,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下

python:自动化测试 playwright 库上传和下载

今天主要是聊聊playwright中的上传和下载操作,playwright中的上传和下载比selenium的上传和下载要简便些,例:selenium中的上传还要有对话框选择文件,再点击上传,而playwright中是找到元素执行点击后设置一个文件位置。

上传

操作语法

# 选择一个文件
page.set_input_files('input#upload', 'myfile.pdf')
# 选择多个文件
page.set_input_files('input#upload', ['file1.txt', 'file2.txt'])
# 删除所有选定的文件
page.set_input_files('input#upload', [])
# 从内存上传缓冲区
page.set_input_files(
    "input#upload",
    files=[
        {"name": "test.txt", "mimeType": "text/plain", "buffer": b"this is a test"}
    ],
)

上述的代码中这种是那种含输入元素(它动态创建的)的上传操作,如果是可点击的上传操作,可以直接使用下述语法:

with page.expect_file_chooser() as fc_info:
    page.click("upload")
file_chooser = fc_info.value
file_chooser.set_files("myfile.pdf")

上传示例
该示例主要演示的是可点击的上传操作,动态输入元素的上传没找到对应示例:

import time
from playwright.sync_api import sync_playwright
with sync_playwright() as p:
    browser = p.chromium.launch(
        headless=False
    )
    page = browser.new_page()
    page.goto("https://域名/user/login")
    page.click('//*[text()="密码登录"]')
    page.click('#user_name')
    page.fill('#user_name', "账号")
    page.click('#password')
    page.fill('#password', "密码")
    page.click('//*[text()="登 录"]')
    time.sleep(2)
    page.click('//*[text()="学习资源"]')
    page.click('//*[@href="/manager/resource/directory" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ]')
    page.click('//*[text()="导入导出"]')
    time.sleep(2)
    with page.expect_file_chooser() as fc_info:
        page.click('//*[text()=" 上传文件"]')
    file_chooser = fc_info.value
    print(file_chooser)
    file_chooser.set_files('E:\playwrightPyinstaller\导入知识目录.xlsx')
  • expect_file_chooser方法是官方提供的上传方法,不作过多解释,用就是了
  • fc_info.value是获取到了上传的相关元素,然后赋值给file_chooser
  • 调用set_files方法,然后传入文件路径

print(file_chooser)打印的结果如下:

<FileChooser page=<Page url='https://域名/manager/resource/directory'> element=JSHandle@<input type="file" accept=".xlsx,.xls"/>>
Process finished with exit code 0

下载

操作语法

# 开始等待下载
with page.expect_download() as download_info:
    # 执行启动下载的操作
    page.click("button#delayed-download")
download = download_info.value
# 等待下载过程完成
path = download.path()

上述代码是下载的语法,这也是处理文件下载的最简单方法。

下载示例

import time
from playwright.sync_api import sync_playwright
with sync_playwright() as p:
    browser = p.chromium.launch(
        headless=False
    )
    context = browser.new_context(
        accept_downloads=True
    )
    page = context.new_page()
    page.goto("https://域名/user/login")
    page.click('//*[text()="密码登录"]')
    page.click('#user_name')
    page.fill('#user_name', "账号")
    page.click('#password')
    page.fill('#password', "密码")
    page.click('//*[text()="登 录"]')
    time.sleep(2)
    page.click('//*[text()="学习资源"]')
    page.click('//*[@href="/manager/resource/directory" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ]')
    page.click('//*[text()="导入导出"]')
    time.sleep(2)
    with page.expect_download() as download_info:
        page.click('//*[@href="//域名/template/导入知识目录.xlsx" rel="external nofollow"  rel="external nofollow" ]')
    download = download_info.value
    print(download)
    print(download.path())
  • 下载和上传的区别就是必须要引入上下文,官网提供的上下文就是使用browser.new_context(accept_downloads=True),方法的括号中必须要有accept_downloads=True,不然运行就会报错。
  • expect_download方法是官方提供的下载方法,不作过多解释,用就是了
  • download_info.value是获取到了上传的相关元素,然后赋值给download

print(file_chooser)打印的结果如下:

<Download url='https://域名/template/%E5%AF%BC%E5%85%A5%E7%9F%A5%E8%AF%86%E7%9B%AE%E5%BD%95.xlsx' suggested_filename='导入知识目录.xlsx'>
Process finished with exit code 0

print(download.path())是获取下载后的存储路径,打印的结果如下:

C:\Users\lifeng\AppData\Local\Temp\playwright-artifacts-H0nUyZ\2b71684d-7471-4055-9581-6cb364b50efc
Process finished with exit code 0

当然您也可以进行自定义存储路径,这个官方也是提供了相应方法:

import time
from playwright.sync_api import sync_playwright
with sync_playwright() as p:
    browser = p.chromium.launch(
        headless=False
    )
    context = browser.new_context(
        accept_downloads=True
    )
    page = context.new_page()
    page.goto("https://lms3.9first.com/user/login")
    page.click('//*[text()="密码登录"]')
    page.click('#user_name')
    page.fill('#user_name', "账号")
    page.click('#password')
    page.fill('#password', "密码")
    page.click('//*[text()="登 录"]')
    time.sleep(2)
    page.click('//*[text()="学习资源"]')
    page.click('//*[@href="/manager/resource/directory" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ]')
    page.click('//*[text()="导入导出"]')
    time.sleep(2)
    with page.expect_download() as download_info:
        page.click('//*[@href="//域名/template/导入知识目录.xlsx" rel="external nofollow"  rel="external nofollow" ]')
    download = download_info.value
    download.save_as('E:\playwrightPyinstaller\导入知识目录.xlsx')

download.save_as(path)方法即是官方提供的自定义路径存储,path路径必须要是路径和文件名称在一起,不然就会抛出权限不足的错误异常。

以上总结或许能帮助到你,或许帮助不到你,但还是希望能帮助到你,如有疑问、歧义,直接私信留言会及时修正发布;非常期待你的点赞和分享哟,谢谢!

到此这篇关于python playwright 库上传和下载操作(自动化测试 playwright )的文章就介绍到这了,更多相关python playwright 库上传和下载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python callable函数使用方法详解

    Python callable函数使用方法详解

    这篇文章主要介绍了Python callable函数使用方法,一个可callable的对象是指可以被调用执行的对象,并且可以传入参数, 用另一个简单的描述方式,只要可以在一个对象的后面使用小括号来执行代码,那么这个对象就是callable对象,下面来详细介绍使用方法,需要的朋友可以参考下
    2024-10-10
  • Python可视化单词统计词频统计中文分词的实现步骤

    Python可视化单词统计词频统计中文分词的实现步骤

    这篇文章主要介绍了Python可视化单词统计词频统计中文分词,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • python如何处理卫星云图获取亮温值

    python如何处理卫星云图获取亮温值

    这篇文章主要介绍了python如何处理卫星云图获取亮温值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Python计算标准差之numpy.std和torch.std的区别

    Python计算标准差之numpy.std和torch.std的区别

    Torch自称为神经网络中的numpy,它会将torch产生的tensor放在GPU中加速运算,就像numpy会把array放在CPU中加速运算,下面这篇文章主要给大家介绍了关于Python Numpy计算标准差之numpy.std和torch.std区别的相关资料,需要的朋友可以参考下
    2022-08-08
  • 用python画个奥运五环(附完整代码)

    用python画个奥运五环(附完整代码)

    大家好,本篇文章主要讲的是用python画个奥运五环(附完整代码),感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • 使用Python统计代码运行时间的两种方法

    使用Python统计代码运行时间的两种方法

    有时候我们需要记录一个程序运行的时间,下面这篇文章主要给大家介绍了关于使用Python统计代码运行时间的两种方法,文中通过图文以及示例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • Python自动化办公Excel模块openpyxl原理及用法解析

    Python自动化办公Excel模块openpyxl原理及用法解析

    这篇文章主要介绍了Python自动化办公Excel模块openpyxl原理及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • PyQt5 实现状态栏永久显示消息

    PyQt5 实现状态栏永久显示消息

    这篇文章主要介绍了PyQt5 实现状态栏永久显示消息的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • Python 获取中文字拼音首个字母的方法

    Python 获取中文字拼音首个字母的方法

    今天小编就为大家分享一篇Python 获取中文字拼音首个字母的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-11-11
  • python中文乱码不着急,先看懂字节和字符

    python中文乱码不着急,先看懂字节和字符

    这篇文章主要介绍了python中文乱码不着急,先看懂字节和字符,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12

最新评论