Base crawler is a Python based tool which facilitates Selenium Framework usage. It enables the development of selenium based crawlers way faster.
- Free software: MIT license
Base Crawler uses selenium to make navigation through websites easier as it gets.
Many selenium functions and interactions are implemented by this application, and you can call them in a very easy way.
Every selenium function can be called by inserting an Action object inside an actions[] array. Everything can be configured in the conf.py file. You can also find out examples of usage in the configuration file or in the section Examples
Be aware you must have a basic knowledge of Python and Selenium to understand how to use this application. To configure your selenium navigation, follow the steps below:
-
Open src/conf.py file.
-
Configure actions_list variable as you like, by adding as many Actions() as you want.
- Action() object can have the following parameters:
Action(action_type, action_target, action_selector_kind, wait_for, wait_for_selector_kind, keys, timeout)
-
action_type:
- goback: Clicks on the browser's GoBack action (Navigates to the previous link).
- gofoward: Clicks on the browser's GoFoward action (Navigates to the next link).
- navigation: Navigates to the action_target value.
- download: Enables Webdriver download and navigates to the action_target value.
- click: Clicks on the WebElement.
- send_keys: Send keys(types) on the WebElement.
- hover: Hover over WebElement.
- drag_and_drop: Drag and drops WebElement.
-
action_target(optional):
- action_target can be any url, element's id, element's selector, element's xpath, element's link or partial link text, element's class or tag name.
- e.g.:
"button_id"
,"nth-child(3) > name"
,"Button Label"
-
action_selector_kind(optional):
- equivalement to driver.find_by_...() selenium's function.
- id: WebElement's id.
- name: WebElement's name.
- xpath: WebElement's xpath.
- link_text: WebElement's link text.
- partial_link_text: WebElement's partial link text.
- tag_name: WebElement's tag name.
- class_name: WebElement's class name.
- css_selector: WebElement's css selector.
-
wait_for(optional):
- wait_for can be any element's id, element's selector, element's xpath, element's link or partial link text, element's class or tag name.
- e.g.:
"button_id"
,"nth-child(3) > name"
,"Button Label"
-
wait_for_selector_kind(optional):
- equivalement to driver.find_by_...() selenium's function.
- id: WebElement's id.
- name: WebElement's name.
- xpath: WebElement's xpath.
- link_text: WebElement's link text.
- partial_link_text: WebElement's partial link text.
- tag_name: WebElement's tag name.
- class_name: WebElement's class name.
- css_selector: WebElement's css selector.
-
keys(optional):
- keys is a paremeter which stores input keys for the Action. It can be use with send_keys action_type.
-
timeout(optional):
- timeout is the amount of seconds the Selenium webdriver will use as it's own timeout before throw an Exception due inactivity.
The project's default example is already enabled on conf.py
file. To set your own configurations, change the Actions() called inside the array named actions_list.
- Example Crawler which navigates to Amazon, searches for products named "roly-poly toy" and clicks on the first item displayed:
actions_list = [
Action('navigation', 'https://www.amazon.com/'),
Action('wait', 5),
Action('click', 'twotabsearchtextbox', 'id'),
Action('send_keys', 'twotabsearchtextbox', 'id', keys='roly-poly toy'),
Action('click', '#nav-search > form > div.nav-right', 'selector'),
Action('wait', 5),
Action('click', '//*[@id="search"]/div[1]/div[2]/div/span[4]/div[2]/div[3]/div/span/div/div/span/a/div', 'xpath')
]
After configuring conf.py
the way you like, as suggested on the Examples section, you must be aware:
- This application supports 2 arguments: browser and timeout.
- browser means which navigator will be instantiatated by Selenium.
- e.g.:
chrome
for Google Chrome orfirefox
for Mozilla Firefox.
- e.g.:
- timeout is the amount of seconds the Selenium webdriver will use as it's own timeout before throw an Exception due inactivity.
- e.g.:
30
for 30 seconds.
- e.g.:
You can easily run the application with the following command:
python -m src.main chrome 30