実行時エラー インデックスが配列の境界外です が表示される
SeleniumBasicでwebDriverを使用して、スクレイピングした際、以下エラーが発生する場合があります。
実行時エラー -2146233080 インデックスが配列の境界外です
実行時エラー -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でのネット記事は少なく困っている方も多いと思います。
弊社で代行開発も可能ですので、お気軽にご用命ください。
コメント