- Webブラウザの自動制御: Seleniumは、さまざまなWebブラウザ(Chrome、Firefox、Safariなど)を制御し、操作するためのAPIを提供します。これにより、ブラウザ上の要素のクリック、テキストの入力、フォームの送信などのアクションを自動化することができます。
例:
from selenium import webdriver
# Chromeを起動
driver = webdriver.Chrome()
# Googleの検索ページを開く
driver.get("https://www.google.com")
# 検索ボックスにキーワードを入力
search_box = driver.find_element_by_name("q")
search_box.send_keys("Selenium")
# 検索ボタンをクリック
search_button = driver.find_element_by_name("btnK")
search_button.click()
# 結果を取得
results = driver.find_elements_by_css_selector("h3")
for result in results:
print(result.text)
# ブラウザを終了
driver.quit()
- 要素の検索と操作: Seleniumは、HTML要素を識別し、操作するためのさまざまなメソッドを提供します。要素の検索にはXPathやCSSセレクタを使用できます。また、要素のクリック、テキストの取得、属性の変更なども行うことができます。
例:
from selenium import webdriver
driver = webdriver.Chrome()
driver.get("https://www.example.com")
# IDによる要素の検索
element = driver.find_element_by_id("myElement")
# テキストの取得
text = element.text
print(text)
# 要素のクリック
element.click()
# 属性の変更
driver.execute_script("arguments[0].setAttribute('class', 'highlighted')", element)
driver.quit()
- ページ遷移とフレームの制御: Seleniumは、ページ遷移やフレームの制御をサポートしています。新しいページやフレームへの切り替え、親フレームへの戻りなどが可能です。
例:
from selenium import webdriver
driver = webdriver.Chrome()
driver.get("https://www.example.com")
# 新しいウィンドウまたはタブの開閉
driver.execute_script("window.open('https://www.google.com')")
driver.switch_to.window(driver.window_handles[1])
driver.close()
driver.switch_to.window(driver.window_handles[0])
# フレームの切り替え
frame = driver.find_element_by_css_selector("iframe")
driver.switch_to.frame(frame)
# 親フレームへの戻り
driver.switch_to.parent_frame()
driver.quit()
- ページのスクリーンショット: Seleniumは、ブラウザの表示内容をスクリーンショットとして保存する機能も提供しています。これにより、テストの実行結果を視覚的に確認することができます。
例:
from selenium import webdriver
driver = webdriver.Chrome()
driver.get("https://www.example.com")
# スクリーンショットの保存
driver.save_screenshot("screenshot.png")
driver.quit()
以上がSeleniumツールセットの主な機能と使用方法の例です。これらの機能を組み合わせて、Webアプリケーションのテスト自動化を行うことができます。Seleniumは広く使用されており、自動化テストのための優れたツールです。この記事を通じて、Seleniumの基本的な機能と使用方法を理解し、自身のテストプロジェクトに活用することができるでしょう。