Есть ли способ добиться перетаскивания для загрузки изображений Magento с помощью Selenium? - PullRequest
6 голосов
/ 11 июля 2019

Я пытаюсь автоматизировать загрузку продукта на magento, используя python и selenium, однако я сталкиваюсь с проблемой загрузки изображений.

Я попытался указать тег ввода с помощью id="fileupload"

driver.find_element_by_id("fileupload").send_keys('C:\\Users\\PC\\Desktop\\Code\\magento-bot\\image1.png')  

Кажется, это работает, потому что, когда я помещаю указатель мыши в область загрузки, появляется имя файла, но после отправки изображение отсутствует.

Я также попытался щелкнуть область загрузки и затем выбрать файл для загрузки, выполнив следующее:

uploadElement = driver.find_element_by_xpath('//html/body/div[2]/main/div[2]/div/div/div/div[2]/div[5]/div[2]/fieldset/div/div[2]/div[1]/div[1]/div[1]')
uploadElement.click()
driver.switch_to.active_element().send_keys(os.getcwd()+"\image1.png)

но я получаю эту ошибку 'FirefoxWebElement' object is not callable Наконец, я попытался смоделировать перетаскивание следующим образом:

element = os.getcwd()+"\image1.png"
target = bot.find_element_by_id('fileupload')
ActionChains(bot).drag_and_drop(element, target).perform

но я получаю ошибку ниже

AttributeError("move_to requires a WebElement")

drag and drop image

Любая помощь будет оценена.

Ответы [ 2 ]

2 голосов
/ 15 июля 2019

Временное решение моей проблемы - AutoIt.

Большое спасибо @KunduK Как загрузить изображение с угловыми компонентами, используя python selenium

Я выбрал xpath области загрузки изображений, затем autoit сделал все остальное с кодом ниже:

autoit.win_wait_active("File Upload",5)
if autoit.win_exists("File Upload"):
   autoit.control_send("File Upload","Edit1",filepath+"{ENTER}")```
2 голосов
/ 14 июля 2019

Вероятно, дубликат ниже

Python с Selenium: перетаскивание из файловой системы в вебдрайвер?

JS_DROP_FILE = """
    var target = arguments[0],
        offsetX = arguments[1],
        offsetY = arguments[2],
        document = target.ownerDocument || document,
        window = document.defaultView || window;

    var input = document.createElement('INPUT');
    input.type = 'file';
    input.onchange = function () {
      var rect = target.getBoundingClientRect(),
          x = rect.left + (offsetX || (rect.width >> 1)),
          y = rect.top + (offsetY || (rect.height >> 1)),
          dataTransfer = { files: this.files };

      ['dragenter', 'dragover', 'drop'].forEach(function (name) {
        var evt = document.createEvent('MouseEvent');
        evt.initMouseEvent(name, !0, !0, window, 0, 0, 0, x, y, !1, !1, !1, !1, 0, null);
        evt.dataTransfer = dataTransfer;
        target.dispatchEvent(evt);
      });

      setTimeout(function () { document.body.removeChild(input); }, 25);
    };
    document.body.appendChild(input);
    return input;
"""

def drag_and_drop_file(drop_target, path):
    driver = drop_target.parent
    file_input = driver.execute_script(JS_DROP_FILE, drop_target, 0, 0)
    file_input.send_keys(path)

См. Также тему ниже

Селен: перетаскивание из файловой системы в WebDriver?

Как моделировать перетаскивание HTML5 в Selenium Webdriver?

...