Automate the Boring Stuff with Python
Page 26
Finding Elements on the Page
WebDriver objects have quite a few methods for finding elements on a page. They are divided into the find_element_* and find_elements_* methods. The find_element_* methods return a single WebElement object, representing the first element on the page that matches your query. The find_elements_* methods return a list of WebElement_* objects for every matching element on the page.
Table 11-3 shows several examples of find_element_* and find_elements_* methods being called on a WebDriver object that’s stored in the variable browser.
Table 11-3. Selenium’s WebDriver Methods for Finding Elements
Method name
WebElement object/list returned
browser.find_element_by_class_name(name) browser.find_elements_by_class_name(name)
Elements that use the CSS class name
browser.find_element_by_css_selector(selector) browser.find_elements_by_css_selector(selector)
Elements that match the CSS selector
browser.find_element_by_id(id) browser.find_elements_by_id(id)
Elements with a matching id attribute value
browser.find_element_by_link_text(text) browser.find_elements_by_link_text(text)
elements that completely match the text provided
browser.find_element_by_partial_link_text(text) browser.find_elements_by_partial_link_text(text)
elements that contain the text provided
browser.find_element_by_name(name) browser.find_elements_by_name(name)
Elements with a matching name attribute value
browser.find_element_by_tag_name(name) browser.find_elements_by_tag_name(name)
Elements with a matching tag name (case insensitive; an element is matched by 'a' and 'A')
Except for the *_by_tag_name() methods, the arguments to all the methods are case sensitive. If no elements exist on the page that match what the method is looking for, the selenium module raises a NoSuchElement exception. If you do not want this exception to crash your program, add try and except statements to your code.
Once you have the WebElement object, you can find out more about it by reading the attributes or calling the methods in Table 11-4.
Table 11-4. WebElement Attributes and Methods
Attribute or method
Description
tag_name
The tag name, such as 'a' for an element
get_attribute(name)
The value for the element’s name attribute
text
The text within the element, such as 'hello' in hello
clear()
For text field or text area elements, clears the text typed into it
is_displayed()
Returns True if the element is visible; otherwise returns False
is_enabled()
For input elements, returns True if the element is enabled; otherwise returns False
is_selected()
For checkbox or radio button elements, returns True if the element is selected; otherwise returns False
location
A dictionary with keys 'x' and 'y' for the position of the element in the page
For example, open a new file editor and enter the following program:
from selenium import webdriver browser = webdriver.Firefox() browser.get('http://inventwithpython.com') try: elem = browser.find_element_by_class_name('bookcover') print('Found <%s> element with that class name!' % (elem.tag_name)) except: print('Was not able to find an element with that name.')
Here we open Firefox and direct it to a URL. On this page, we try to find elements with the class name 'bookcover', and if such an element is found, we print its tag name using the tag_name attribute. If no such element was found, we print a different message.
This program will output the following:
Found element with that class name!
We found an element with the class name 'bookcover' and the tag name 'img'.
Clicking the Page
WebElement objects returned from the find_element_* and find_elements_* methods have a click() method that simulates a mouse click on that element. This method can be used to follow a link, make a selection on a radio button, click a Submit button, or trigger whatever else might happen when the element is clicked by the mouse. For example, enter the following into the interactive shell:
>>> from selenium import webdriver >>> browser = webdriver.Firefox() >>> browser.get('http://inventwithpython.com') >>> linkElem = browser.find_element_by_link_text('Read It Online') >>> type(linkElem)
This opens Firefox to http://inventwithpython.com/, gets the WebElement object for the element with the text Read It Online, and then simulates clicking that element. It’s just like if you clicked the link yourself; the browser then follows that link.
Filling Out and Submitting Forms
Sending keystrokes to text fields on a web page is a matter of finding the or