トップページ > Selenium API(逆引き) > 【Python】on_exception

【Python】on_exception・・・Exception発生後の処理を実施する

【PR】業界トップクラスの「高単価報酬」「低マージン」を実現!レバテックフリーランス

「on_exception」を実行することでException発生後の処理を実施することが出来ます。

イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをMyListenerクラスと命名します。MyListenerクラスは、AbstractEventListenerクラスを継承して作成されたサブクラスです。AbstractEventListenerクラスの関数はダミー実装がされているためMyListenerクラスでイベントに対応した各関数をオーバーライドする必要があります。ここでは、「on_exception」の関数の内容をオーバーライドしています。

それでは、実際にイベント発生させていきます。イベントを発生させる前に、イベント発生クラスである「EventFiringWebDriver」コンストラクタの第1引数にWebDriverのインスタンス、第2引数にイベント捕捉クラスのインスタンスを指定して、イベント発生クラスのインスタンスを作成していきます。そしてそのインスタンスに対して、ページ遷移(GoogleTopページ)をしています。

この段階では、「on_exception」の関数が自動で呼び出される条件は満たしていません。これらの関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、Exceptionが発生した時です。そのため、下記サンプルを例にすると、Google Topページ上の存在しないid属性値を指定して要素取得を行った後、「on_exception」が実行されます。

※イベント処理についてはこちら

説明

◆メソッド
  ・on_exception(self, exception, driver)
◆使用形態
  ・上記メソッドはあらかじめAbstractEventListenerクラスを継承して
         オーバーライドしておく。
◆備考
  ・このイベントはexceptionが起こることによって発生する
◆関連項目
  ・要素がクリックされる直前/直後の処理を実施する
  ・ブラウザの『戻る』または『進む』に対して直前/直後の処理を実施する

サンプル

from selenium import webdriver
from selenium.webdriver.chrome import service
from selenium.webdriver.common.by import By
from selenium.webdriver.support.event_firing_webdriver import EventFiringWebDriver
from sub_abstract import MyListener

#ChromeDriverのパスを変数に設定
CHROMEDRIVER = "D:\driver\chromedriver.exe"
#ChromeDriverのstartとstopを制御するServiceオブジェクトを介してパスを渡す
chrome_service = service.Service(executable_path=CHROMEDRIVER)
#Chromeを起動
driver = webdriver.Chrome(service=chrome_service)
#イベント発生クラスの引数に以下を指定する
#第1引数:WebDriverのインスタンス
#第2引数:イベント捕捉クラスのインスタンス
efw_driver = EventFiringWebDriver(driver, MyListener())
#別サイトへ遷移する
efw_driver.get("https://www.google.co.jp")
#存在しないidの要素取得をしてExceptionを発生させる
element = efw_driver.find_element(By.ID, "ABCDE")
from selenium.webdriver.support.abstract_event_listener import AbstractEventListener

#「sub_abstract.py」でイベント捕捉クラス(MyListenerクラス)を定義する
#MyListenerクラスはAbstractEventListenerクラスのサブクラス
#AbstractEventListenerクラスでは関数がダミー実装されており、MyListenerクラスで関数をオーバーライドしていく
class MyListener(AbstractEventListener):
    def on_exception(self, exception, driver):
        #exception発生後の処理
        print("on_exception:Exception occurred!")
※selenium version 4.1.3で動作確認をしています(ブラウザのUIや属性値などが変更された場合、実行結果が異なる可能性があります)

実行結果

on_exception:Exception occurred!

Fatal error: Uncaught Google_Service_Exception: Error calling GET https://www.googleapis.com/analytics/v3/data/ga?ids=ga%3A138132118&start-date=7daysAgo&end-date=yesterday&metrics=ga%3Apageviews&dimensions=ga%3ApageTitle%2C+ga%3ApagePath&sort=-ga%3Apageviews&max-results=1000: (403) User does not have sufficient permissions for this profile. in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php:110 Stack trace: #0 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(62): Google_Http_REST::decodeHttpResponse(Object(Google_Http_Request), Object(Google_Client)) #1 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Task/Runner.php(174): Google_Http_REST::doExecute(Object(Google_Client), Object(Google_Http_Request)) #2 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(46): Google_Task_Runner->run() #3 /home/users/1/monda-muki/web/seleniumqref in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110