使用Selenium通过MacOS窗口上载图像

2024-09-27 21:31:53 发布

您现在位置:Python中文网/ 问答频道 /正文

设置

我正在使用python3.x和Selenium来处理webshop的后端。在

我需要在平台的后端从我的电脑上传产品图片。在


问题

使用Selenium可以单击图像上载按钮,但是单击会导致出现MacOS文件选择器。在

Selenium在MacOS文件选择器上不起作用。我研究过如何解决这个问题,找到了以下答案:

  1. https://stackoverflow.com/a/6129464/7326714
  2. http://www.seleniumstutorial.com/uploading-a-file-in-selenium-with-python/
  3. https://stackoverflow.com/a/10472542/7326714

然而,这些都不管用。在

按钮周围的html是

<td class="control">


<div class="hide-input">
    <input data-val="true" data-val-required="The Image field is required." id="FileName" name="FileName" type="text" value="File636578585362423712.png">
</div>

<div id="uploadifive-FileNameUpload" class="uploadifive-button" style="height: 18px; line-height: 18px; overflow: hidden; position: relative; text-align: center; width: 50px;">Upload<input id="FileNameUpload" type="file" name="FileNameUpload" data-editor="#FileName" data-url="http://also-inc.demohoster.com/upload/uploadfile" data-path="~/UserFiles/Products/Images/" data-maxsize="10240" data-extensions="*.jpg;*.jpeg;*.png;*.gif;*.bmp;" data-thumbnailwidth="128" data-thumbnailheight="128" data-thumbnailpath="/UserFiles/Products/Images/Preview/" data-uniquename="True" data-preview="/UserFiles/Products/Images/Preview/File636578585362423712.png" data-isnew="false" data-auth="2CDE59B99D5F034087CA006254189C31F4388BA02DDE1CD1752A2FCFDE6EB556406CAF9D82DE4E02AC4D7D9813E2CF8B2A1413EF7CE8CA22FDD9822130B4EC239F1BD305F8AA1E5F6E9EFD1CD64138B8A621A88A675A3A528B7DF2F0388C36C473CBAD080CF826A28A3464FB719D039690241E38" data-session="jx134u0kcaxfu4jz1darurvg" class="file-uploader hide-input" style="display: none;"><input type="file" style="font-size: 18px; opacity: 0; position: absolute; right: -3px; top: -3px; z-index: 999;"></div>
<div id="uploadifive-FileNameUpload-queue" class="uploadifive-queue"></div>
</td>

尝试

我试过点击按钮然后发送按键

^{pr2}$

(也尝试了id 'uploadifive-FileNameUpload-queue'和id 'FileName'的所有可能的组合)

我尝试过不点击就发送,即browser.find_element_by_id('uploadifive-FileNameUpload').send_keys('path/to/MyImage.jpeg')。所有的钥匙也一样。在

不管我怎么做,我总是得到一个ElementNotInteractableException。在


这是我第一次尝试用这种方式上传图片,我被卡住了。在

我怎么解决这个问题?在


Tags: divcomidinputdatapngstyletype
1条回答
网友
1楼 · 发布于 2024-09-27 21:31:53

禁用文件选择器并调用sendKeys上的<input type="file">,这是设计上唯一允许接收/保存文件的元素类型:

# disable the OS file picker
browser.execute_script("""
    document.addEventListener('click', function(evt) {
      if (evt.target.type === 'file')
        evt.preventDefault();
    }, true)
    """)

# make an <input type="file"> available
browser.find_element_by_id('uploadifive-FileNameUpload')\
    .click()

# assign the file to the <input type="file">
browser.find_element_by_css_selector('input[type=file]')\
    .send_keys('path/to/MyImage.jpeg')

相关问题 更多 >

    热门问题