51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 709|回复: 0
打印 上一主题 下一主题

[转贴] Selenium浏览器自动化怎么上传文件

[复制链接]
  • TA的每日心情
    无聊
    前天 09:05
  • 签到天数: 1050 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-7-6 09:39:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     Selenium 封装了现成的文件上传操作。但是随着现代前端框架的发展,文件上传的方式越来越多样。而有一些文件上传的控件,要做自动化控制会更复杂一些,这篇文章主要讨论在复杂情况下,如何通过自动化完成文件上传。
      1. input 元素上传文件
      如果页面需要文件上传,那么在大多数情况下,都能在页面源代码中找到一个input的元素。
    1.   <input type="file" name="file_name">
    复制代码
    如果能直接在页面当中看到这个input元素,那么通过 selenium 的 send_keys 方法就能完成文件的上传,在参数中传入本地文件的路径。

    1. driver.get('<https://testpages.herokuapp.com/styled/file-upload-test.html>')
    2.   el = driver.find_element('id', "fileinput")
    3.   el.send_keys('/path/of/file.png')
    复制代码
    2. input 元素隐藏
      通过修改元素属性,把隐藏的元素属性改掉。
    1. el = driver.find_element('xpath', '//input[@type="file"]')
    2.   driver.execute_script('arguments[0].style.visibility=\\'visible\\'', el)
    3.   el.send_keys(r'C:\\Users\\muji\\Desktop\\avatar.png')
    复制代码
    比如可以通过这种方式实现百度的以图搜图。
    1. driver.get('<http://www.baidu.com>')
    2.   driver.find_element('css selector', '.soutu-btn').click()
    3.   time.sleep(3)
    4.   el = driver.find_element('xpath', '//input[@type="file"]')
    5.   driver.execute_script('arguments[0].style.visibility=\\'visible\\'', el)
    6.   el.send_keys(r'C:\\Users\\muji\\Desktop\\avatar.png')
    复制代码
    3. 文件选择对话框
      对于有一些元素,直接通过 selenium 自带的 send_keys 方法上传文件并不会成功。如果不想对input元素进行过多的分析,那么比较直接的方式是采用文件上传对话框来处理。
      一般来说,如果需要上传文件,那么当你点击这个元素之后,会出现一个文件上传的对话框,要求你选择文件,并点击确定。这个对话框是属于系统的,因此selenium 无法直接控制它。我们可以采用系统的自动化工具或者直接调用键盘来操作这种对话框。
      在操作对话框之前,首先我们通过 selenium 点击文件上传的元素。
    1.  el = driver.find_element('id', "fileinput")
    2.   ActionChains(driver).click(el).perform()
    复制代码
    input 元素并不能点击,所以不能用元素的 el.click() 方法,需要使用 ActionChains 下面的 click 方法。他们之间的区别在于元素的 el.click 方法更加严格,会对元素是否可见,是否可点击进行检测,在点击事件完全生效后,再执行下面的操作,如果不满足这些条件,可能会报错。 而 Action 下的 click 方法则粗暴得多,它几乎不对对元素进行检测,直接把鼠标移动到元素上方,执行点击操作,至于点击是否生效,根本不管。
      4. 使用 pywinauto 上传文件
      pywinauto 是Windows系统下的一个自动化工具,它可以直接获取到Windows系统下面的弹框,因此当文件上传的窗口出现之后,我们可以使用这个工具传入文件的路径,然后点击打开按钮。
    1. from pywinauto import Desktop
    2.   app = Desktop()
    3.   dialog = app['打开']  # 根据名字找到弹出窗口
    4.   dialog["Edit"].type_keys('/path/of/file.md')  # 在输入框中输入值
    5.   dialog["Button"].click()
    复制代码
    另一种系统自动化工具叫做 pyautogui。这个工具最大的特点在于使用坐标系统定位元素,可以轻而易举的做到跨平台。不管你是Windows,mac还是[url=]Linux[/url],都可以使用这款工具实现自动化。
      但是这款工具目前不支持中文的输入,因此我们需要借助剪切板来实现中输入。首先我们把对应的中文复制到剪切板当中,然后再通过 ctrl + v 热键粘贴到文件路径输入框当中。
    5. pyautogui
    import pyperclip
       pyperclip.copy('D:\\\\用户.html')
       pyautogui.hotkey('ctrl', 'v')
       pyautogui.press('enter', presses=2)

    键盘
    keyboard.write('C:\\\\Users\\\\muji\\\\Desktop\\\\avatar.png')
      time.sleep(1)
      keyboard.press('enter')

    注意:百度以图搜图禁用了爬虫,所以在上传文件时会提示「图片上传失败,请重新上传」。
      6. 并发问题
      通过系统窗口上传文件简单粗暴,但是当你的程序需要并发执行时,使用这种方式实现文件上传就比较麻烦了。如果你的程序需要并发执行,最好还是通过控制input元素,使用 send_keys 方法实现文件上传。









    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 02:38 , Processed in 0.073373 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表