質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

Q&A

解決済

2回答

3243閲覧

Excel VBA で chrome で 検索して表示されている 項目名を 取得したい

akane2000

総合スコア13

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

0グッド

1クリップ

投稿2019/05/05 05:00

VBA + Selenium Basic で Google 検索したときに 1ページに表示される 検索結果(項目目) を 取得したいのですが、下のプログラム で 実行したときに
「a(i) = .FindElementByClass("LC20lb").Text」の部分で エラーになります。

どなたか 解決方法をご教授ください。

よろしくお願いします。

エラーは次の内容です。
実行時エラー 7:
NoSuchElementError
Element not found for Class=LC20lb

Dim driver As New ChromeDriver Dim a As Variant

Sub Main()
driver.Get ("https://www.google.com")

'テスト用語「A」
driver.FindElementByName("q").SendKeys ("A")
driver.Wait 500
driver.FindElementByName("btnK").Click

count = driver.FindElementsByClass("LC20lb").count For i = 1 To count With driver.FindElementsByClass("LC20lb")(i) a(i) = .FindElementByClass("LC20lb").Text End With Next i ' ブラウザを閉じる. driver.Quit

End Sub

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ExcelVBAer

2019/05/07 03:49

問題の切り分けが必要です。 .FindElementByClass("LC20lb") がエラーになるのか、 .Text がエラーになるのか
guest

回答2

0

for 文の直前の行にbreak pointを設定してマクロを起動し、break pointで停止したらdriverという変数をウォッチ式に入れると構造が見えるはずです。
そこに
driver.FindElementsByClass("LC20lb")(i).FindElementByClass("LC20lb").Text
がないからエラーになっています。
あなたがアクセスしたい変数が何かはエスパーじゃないので分かりません。

投稿2019/05/05 07:14

sage

総合スコア1216

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akane2000

2019/05/05 07:21

sage様 ありがとうございます。 お怒りなさらずご教授下さい。 sage様みたいに全てがわかってませんので、 すみません。 htmlをもう少し理解しないと出来ないのかもしれません。 LC20lb という クラスの テキスト文を 取得したいだけです。。。
guest

0

ベストアンサー

ChromeDriver型という型定義を使っているようですね。

この定義にない要素を指定したからエラーになったようです。

with文の機能を理解していますか?
(誤解があるように見えます)

投稿2019/05/05 06:52

sage

総合スコア1216

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akane2000

2019/05/05 07:06

sage様 ありがとうございます。 試行錯誤しております。 是非具体的な解決法をご教授下さい。 vba+selenium の 詳しい方 よろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問