Selenium(Edge/Chrome)

実行時エラー インデックスが配列の境界外ですの対処法【Selenium】【ExcelVBA】

実行時エラー インデックスが配列の境界外です が表示される

SeleniumBasicでwebDriverを使用して、スクレイピングした際、以下エラーが発生する場合があります。
実行時エラー -2146233080 インデックスが配列の境界外です

実行時エラー インデックスが配列の境界外です が表示される原因

単純に要素の指定ミスが考えられます。

IE自動操作(IEオートメーション)で慣れていると、
SeleniumBasicのコード記載方法で間違ってしまう場合があります。
添え字は0スタートではなく1スタートです。

実行時エラー インデックスが配列の境界外です が発生するサンプルコード

    '■複数形のElementsの添え字を0スタートにしてしまっている
    driver.FindElementsByClass("userID")(0).SendKeys "test"        '×エラー438
    driver.FindElementsByClass("userID")(1).SendKeys "test"        '〇正解のコード
    
    '■複数形のElementsの要素は10個しかないのに、範囲外を指定している
    driver.FindElementsByName("s")(11).SendKeys "test"        '×エラー438
    driver.FindElementsByNmae("s")(10).SendKeys "test"        '〇正解のコード

 

SeleniumBasicについて

Internet Explorer11 のサポート期限が2022年6月までと、スクレイピング自体入れ替えていく必要があります。
今一番スムーズなのはSeleniumBasicを使用したスクレイピングと考えます。

但し、VBAでのネット記事は少なく困っている方も多いと思います。
弊社で代行開発も可能ですので、お気軽にご用命ください。

コメント

タイトルとURLをコピーしました