- How to get window size, resize or maximize window using Selenium WebDriver
- Example
- Output
- Example
- Output
- Python
- Selenium размер окна при запуске firefox
- Selenium WebDriver: изменить размеры и расположение окна браузера
- Начинаем работать с Selenium в Python
- Введение
- Что такое Selenium?
- Подготовка к работе
- Основы работы с Selenium
- Положение элементов на странице
- Получение элементов и их содержимого по id
- Получение элементов по значению атрибута name
- Получение элементов по имени класса
- Получение элементов по имени тега HTML
- Получение элементов с использованием синктаксиса XPath
- Selenium WebElement
- Selenium WebDriver
- Навигация по странице
- Доступ к файлам cookie
- Изменение HTML кода страницы
- Загрузка файлов с использованием ссылок на скачивание
- Нажатие клавиш клавиатуры
- Нажатия на кнопки и другие HTML элементы
- Ввод данных в элементы ввода форм
- Скроллинг
- Заключение
How to get window size, resize or maximize window using Selenium WebDriver
Published: February 23, 2014 by Yi Zeng (Last updated: January 16, 2017 )
Recently Updated — January 16, 2017
Selenium WebDriver supports getting the browser window size, resizing and maximizing window natively from its API, no JavaScript injections like window.resizeTo(X, Y); are necessary any more. Below shows the examples on how to achieve this in Selenium WebDriver C#, Ruby and Python bindings.
In Ruby binding, window size can be retrieved from method driver.manage.window.size , which is a type of struct Selenium::WebDriver::Dimension defined here. To resize a window, one solution is to create a new Dimension object and assign it to property driver.manage.window.size . Alternatively, Ruby binding has provided a driver.manage.window.resize_to() method, which is equivalent to #size= , but accepts width and height arguments according to API here.
Environment Tested:
Mac OS Sierra, Ruby 2.3.1p112, Selenium 3.0.5, ChromDriver 2.26, GeckoDriver 0.13
Firefox 50.1, Chrome 55, PhantomJS 1.9.8
Example
Output
Similarly in C# binding, a browser window’s size can be found out using driver.Manage().Window.Size property. The same IWindow interface also defines method Maximize() for maximizing the window. Although this interface doesn’t provide a function to resize window directly like Ruby binding, it can be done by setting the Size property using System.Drawing.Size object 1 .
Environment Tested:
Windows 7, Selenium 2.39.0, Firefox 26.0
Example
Output
Python
Unlike C# and Ruby bindings, Python binding doesn’t offer properties to get/set window size, all get/set/maximize actions are available using methods defined in selenium.webdriver.remote.webdriver.
Environment Tested:
Window 7, Python 2.7, Selenium 2.40.0, Firefox 26.0
Selenium размер окна при запуске firefox
Изменить размер окна в Selenium
Не могу понять from selenium import webdriver import time driver = webdriver.Firefox().
Окна в Qt размер и положение при запуске
Здравствуйте! Как сделать в Qt что бы окно запускалось жестко только с правой или левой стороны.
Размер компонентов GUI при запуске jar больше чем при запуске в IDE
Вообщем есть такая вот проблема: Еще с давних пор когда начинал изучать Swing заметил, что при.
Selenium Firefox driver и плагины Firefox
Если в селениуме используется файерфокс драйвер, то возможно ли его запускать с плагинами? Т.к.
это для chrome.browser
Добавлено через 16 минут
Абсолютно рабочий вариант, просто подставляем в опции при инициализации браузера.
Но если вы хотите изменить любые настройки, то вначале найдите их, для этого в адресной строке пропишите «about :config».
Далее
Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь или здесь.
Реклма при запуске браузера Firefox
реклама при запуске браузера Firefox
Как при запуске lubuntu запустить Firefox?
Стоит такая задача) Есть древние компы с lubuntu там только сдают экзамены через Firefox) 1.
Firefox при запуске ПК заходит на сайт gangnamgame
Насколько я понял проблема у всех индивидуально решается, поэтому вот. Запускаю пк и браузер сразу.
Selenium WebDriver: изменить размеры и расположение окна браузера
Для управления положением и размерами текущего окна WebDriver предоставляет интерфейс Window :
driver.manage().window();
Обратите внимание, что управление происходит именно текущим окном, на которое установлен фокус драйвера. Для того, чтобы получить доступ к другим открытым окнам, необходимо сперва переключиться в необходимое окно с помощью метода switchTo() и только после этого вызывать его управление.
Размер
Изменить текущие размеры окна браузера можно с помощью следующего метода:
Метод setSize изменяет именно внешний размер окна, а не просто вьюпорт браузера. При этом заданный размер устанавливается только для текущего окна, на которое смотрит драйвер, не затрагивая другие окна. А вот что касается будущих открытых окон, то они будут открываться с учетом установленных размеров (кроме IE).
Приведенный код можно вызывать в любой момент выполнения теста, главное после инициализации драйвера.
Для того, чтобы сразу развернуть браузер на весь экран предоставляется еще один специальный метод:
Текущий размер окна можно получить с помощью соответствующего метода:
Эти методы одинаково хорошо работают для браузеров Firefox, InternetExplorer и Chrome.
Для браузера Google Chrome есть также возможность установить его размеры перед запуском. Для этого нужно запустить Chrome c заданными предустановками:
Расположение
Для работы с местоположением окна интерфейс Window содержит два метода:
Точкой отсчета для этих методов служит левый верхний угол экрана.
Для Google Chrome есть специальный флаг —window-position=x,y , с помощью которого можно открыть браузер сразу с заданными координатами.
Начинаем работать с Selenium в Python
Введение
Автоматизация работы с веб-браузером набирает все большую популярность и в настоящее время появилось много инструментов, предоставляющих разработчикам эту возможность, от «всемогущих» фреймворков настоящих «швейцарских ножей» до узкоспециализированных утилит.
Автоматизация взаимодействия пользователя с веб-браузером часто используется как для тестирования в ходе процесса разработки ( development ), так и на стадии завершении работы над проектом ( production ). Также автоматизация управления веб-браузером может использоваться для извлечения данных из открытых источников сети Интернет для последующего анализа и обработки полученных данных.
То как вы используете технологии автоматизации работы с браузером будет зависит только от вас, просто убедитесь, что то, что вы делаете является законным. Поскольку «боты», созданные с помощью инструментов автоматизации, могут нарушать законные права владельцев контента сайтов или процесс функционирование сайта.
Selenium является одним из наиболее широко используемых инструментов автоматизации веб-браузера, и предлагает широкий функционал для управления браузером.
Он поддерживает многие языки, такие как C #, Java, Perl, PHP и Ruby. Однако в нашей статье изложены материалы по его использованию с Python в Windows.
Что такое Selenium?
Selenium — отличный инструмент, который позволяет разработчикам эмулировать (имитировать) действия в браузере пользователя с использованием всего лишь нескольких строк кода. Используя инструменты, которые он предлагает, очень легко реализуется загрузка содержимого веб-страниц в браузер, а также имитация взаимодействия пользователя с её элементами и даже с учетом особенностей человеческого поведения.
Так для борьбы с «ботами», имитирующими поведение людей, используются сложные специализированные системы для распознавания поведения, подобного человеку, которое иногда невозможно воспроизвести с помощью инструментов автоматизации работы с веб-браузером.
Поэтому если вы создаете приложение с помощью Selenium, убедитесь, что вы не нарушаете законов, связанных с правилами Web Browser Automation . Используйте его для целей тестирования в при разработке собственных проектов.
Перечислим некоторые из наиболее популярных задач, решаемых с помощью Selenium, хотя весь их список конечно же не ограничивается приведенными ниже:
- нажатие кнопок;
- ввод текста;
- извлечение текста;
- доступ к данным в cookie файлах;
- нажатие клавиш.
Подготовка к работе
Прежде чем мы начнем, нам необходимо проделать следующие операции:
- Установка браузер Google Chrome на свой компьютер — далее мы будем имитировать действия пользователя в браузере Google Chrome. Хотя вы конечно же можете использовать Selenium в других браузерах, но в этой статье я буду описывать способы работы с Google Chrome.
- Загрузите chromedriver.exe , в дальнейшем вам потребуется указать путь к этому исполняемому файлу на вашем компьютере.
- Установите пакет selenium package запустив в консоли команду pip install selenium .
Основы работы с Selenium
Отлично, теперь мы готовы начать работать с Selenium. Попробуем запустить браузер и перейти по заданному URL:
Запуск этого кода на исполнение откроет Google Chrome и перенаправит его по адресу https://www.google.com . Как видно из листинга кода подключение к веб-странице осуществляется с помощью метода get(URL) объекта driver .
driver — это экземпляр класса WebDriver импортируемого из пакета Selenium , который мы далее будем использовать для управлению действиями браузера, например:
Код выше выведет в консоли исходный HTML код всего содержимого нашей страницы, полученного с помощью метода get(URL) . Поэтому если вам в дальнейшем необходимо будет просмотреть содержимое запрашиваемой страницы, то этот прием вам пригодится.
Положение элементов на странице
Как правило, вам совсем не нужно всё содержимое страницы, а лишь только её отдельных частей (HTML элементов). Поэтому вначале необходимо определить местоположение нужного нам HTML элемента на странице, для этого можно использовать инструмент Inspect Element из состава web developer tools браузера Google Chrome.
Для решения нашей задачи, нам необходимо узнать идентификатор тега элемента, над содержимым которого мы хотим затем поработать. И для этого необходимо сделать следующее в обычной сессии Google Chome:
- Щелкните правой кнопкой мыши на элементе
Выберите в контекстном меню «Просмотреть код»
Как ещё можно использовать этот инструмент для поиска элементов на странице, вы можете прочитать на официальном сайте.
Отметим, что полученный таким способом идентификатор должен однозначно указывать на нужный нам HTML элемент. Если в качестве идентификатор мы указываем его уникальный на целевой странице id , то наш код, обрабатывающий содержимое элемента, будет работать так, как мы хотим. Но в случае если в качестве идентификатора мы будем использовать значение других атрибутов тега, например class , то полученные результаты могут отличаться от ожидаемых.
Получив идентификаторы нужных нам элементов, мы можем выполнять над ними и их содержимым различные действия.
Получение элементов и их содержимого по id
Если знаете id нужного вам элемента, то его со всем содержимым, а также вложенными элементами, можно легко получить следующим способом:
Получение элементов по значению атрибута name
Аналогично предыдущему примеру:
Получение элементов по имени класса
И снова, аналогично предыдущему примеру кода:
Получение элементов по имени тега HTML
Так же вы можете получить элементы страницы по имени тега:
В этом случае переменная links получает все элементы с тегом a , находящиеся на загруженной странице .
Получение элементов с использованием синктаксиса XPath
Как вы понимаете не все элементы страницы могут иметь уникальный идентификатор. Или, например, получив доступ с помощью метода find_elements_by_tag_name ко всем элементам на странице с заданным тегом, нам в принципе не нужно содержимое каждого из них, а лишь одного конкретного элемента из выборки.
Для решения подобных задач были разработаны другие способы получения содержимого конкретного элемента на странице, например, с использованием синтаксиса XPath (языка запросов к элементам XML документа). С использованием XPath вы сможете находить элементы на странице более быстрым и эффективным способом:
Переменная tag_list теперь содержит все элементы страницы с тегом tag у которого задан атрибут attr с установленным значением val :
Теперь вы можете перебирать итерируемый объект tag_list и обрабатывать по отдельности его элементы, имеющие тип WebElement , описанный в пакете Selenium.
Вы можете больше прочитать об использовании XPath в Selenium по ссылке .
Selenium WebElement
Класс WebElement , определенный в Selenium, по сути является представлением обычного HTML элемента. С ним вы можете выполнять все те же операции, как и с обычными HTML элементами на странице, подобно тому, как взаимодействует с ними конечный пользователь.
Перечислим основные из них:
- Доступ к простым свойствам элемента, таким как текст внутри: element.text
- Доступ к родительским элементам, которые также имеют тип WebElement : element.parent
- Доступ к атрибутам элементов, таким как href тега a : element.get_attribute(‘href’)
- Поиск в содержимом элемента (так же, как в глобальном корневом объекте driver )
- Кликать по нему (нажимать на нем левой кнопкой мыши): element.click()
- Пользовательский ввод в элемент текстовой информации, если это возможно для его типа: element.send_keys(‘Input Text’)
Selenium WebDriver
Объект WebDriver схож с WebElement , однако их основным отличием является контекст его применения. Таким образом, область действия последнего — это сам элемент, а первого — вся страница в целом.
С помощью объекта WebDriver вы можете осуществлять множество операций, а точнее практически проделывать все действия, что может сделать человек с обычным браузером.
Вот некоторые полезные его полезные возможности:
- Запуск на странице произвольных JavaScript скриптов: driver.execute_script(«script»)
- Сохранять скриншоты страницы: driver.save_screenshot(‘image.png’)
- Включить режим работы браузера в режиме «headless» ( Как работает Headless Chrome ). Таким образом браузер экономит время, исключая этап рендеринга страницы:
Обратите внимание на то, что в методе set_window_size указывается размер окна браузера, он устанавливается равным (1440, 900) . Это важно для предотвращения ситуаций, связанных с присутствием на странице элементов, которые могут не загружаются в «headless» режиме (загрузка которых зависит от текущего размера окна браузера, а точнее размера экрана устройства).
Вы можете изменять разрешение или размер окна браузера на любое другое значение, но вы должны помнить, что в этом случае для текущего экземпляра объекта driver это значение будет установлено по умолчанию.
Навигация по странице
Доступ к файлам cookie
Вам может понадобиться добавить или удалить файлы cookie браузера, с заданным содержимым:
Этот код предписывает браузеру создать файлы cookie с заданными значениями атрибутов some_attr и some_other_attr . Это может быть использовано, в случае если вам необходимо добавить в файлы cookie данные аутентификации или другую информацию. Напомним, что содержимое файла cookie имеет формат схожий с синтаксисом словаря dict .
Также очень легко получить cookie из текущей сессии браузера:
Приведенный выше код выведет в консоли содержимое каждого файла cookie из текущей сессии браузера.
Изменение HTML кода страницы
Если вам понадобилось изменить свойства определенного HTML элемента страницы, например, добавить или удалить его атрибуты и т. д. То как уже упоминалось ранее, вы можете использовать объект Selenium WebDriver для выполнения произвольного JavaScript кода на загруженной странице. Таким образом с помощью JavaScript можно легко изменять любые свойства элементов страницы:
Здесь element — это элемент страницы, полученный любым из описанных выше способов. attr соответственно его атрибут, который нужно изменить (или добавить), а value — его значение.
Загрузка файлов с использованием ссылок на скачивание
Допустим вам необходимо загрузить какой-либо файл с веб-сайта. Следующий код поможет это осуществить:
Также вы можете указать путь к папке для сохранения скаченного файла, определив значение свойства download.default_directory , например, так — path\to\directory .
Нажатие клавиш клавиатуры
Этот код эмулирует нажатие клавиши «стрелка вниз» ( Keys.ARROW_DOWN ) 3 раза. После каждого нажатия action.send_keys(Keys.ARROW_DOWN) программа ожидает небольшой промежуток времени (0.1 сек.).
Этот прием рекомендуется использовать для того, чтобы убедиться, что в текущем окне браузера зарегистрированы обработчики событий нажимаемых клавиш. Также этот способ применяется для исключения ситуаций, когда команды нажатия клавиш могут «потеряться» в процессе взаимодействия с браузером (например, страница не успела загрузится и соответствующие обработчики событий элементов не были назначены), то есть они просто не будут зарегистрированы и исполнены в последствии.
Таким образом, объект Keys позволяет эмулировать нажатия любых клавиш вашей клавиатурой. Что позволяет, например, использовать событие Keys.TAB (нажатие клавиши Tab ) для перемещения фокуса между элементами ввода в формах (касается элементов, способных принимать фокус для ввода с клавиатуры). Или эмулировать нажатие клавиш Keys.RETURN и Keys.SPACE , что облегчает взаимодействие с элементами ввода данных, а также имитирует поведение человека.
Нажатия на кнопки и другие HTML элементы
Как уже говорилось выше, вы можете использовать эмуляцию событий нажатия клавиши Tab для перемещения между элементами на странице, клавиши Space (пробел) для заполнения checkbox (флажков), а также клавиш со стрелками для перемещения между пунктами выпадающего меню.
Но более простым является следующий способ реализации взаимодействия с HTML элементами, такими как button или элементами option выпадающего списка значений select . Способ включает в себя выполнение следующих действий: поиск и получение конкретного элемента на странице с помощью объекта webdriver , а затем инициирование клика по нему:
Ввод данных в элементы ввода форм
Вы также можете эмулировать нажатия клавиш внутри HTML элементов ввода в формы текстовой информации:
Таким способом, например, вы можете поместить текстовую информацию в элемент text или textarea .
Кстати, код выше использует сочетание клавиш ( CTRL + A ) для выделения всего текста внутри элемента element . А следующая строка заменяет выделенный текст заданным произвольным строковым значением из переменной value .
И так, для эмуляции нажатия сочетаний клавиш передавайте их через параметры метода send_keys .
Скроллинг
Иногда некоторые части страницы загружаются только после ее прокрутки вниз. Например, канал в Instagram или любая другая страница с “бесконечной” прокруткой (с использованием AJAX). C помощью приведенного ниже скрипта JavaScript можно прокрутить страницу браузера вниз:
Приведенный выше код использует команды языка JavaScript для прокрутки до нижней части страницы, теперь вы можете использовать метод driver.page_source и получить полное содержимое страницы.
Заключение
Selenium — один из наиболее широко используемых инструментов для автоматизации работы с веб-браузером, который предлагает множество функций и возможностей для просмотра и сбора информации. В основном он используется для автоматизации тестирования веб-приложений в ходе разработки, хотя его также можно эффективно использовать в качестве инструмента для сбора информации ( web scraping ).
Соблюдайте законы, если вы осуществляете сбор контента из ресурсов Интернет. Не нарушайте авторские права 😉