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

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

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

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

selenium

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

Q&A

解決済

1回答

2357閲覧

Python Selenium 孫要素の最初に検出したaタグを取得したい

navca

総合スコア44

Chrome

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

selenium

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

0グッド

0クリップ

投稿2018/11/13 08:08

初心者ですがよろしくお願い致します。
seleniumを使用しています。

<div> <div> <div> <div> <div> <a></a> </div> <div></div> </div> </div> </div> <div> <div> <div> </div> </div> </div> <div> </div> </div>

上記のような複数ネストされた構造で、一番最初に見つかったaタグを取得したいのですが、ループしか方法がないんでしょうか?
このような処理を複数書かなくてはならないのでループは極力減らしたいのですが、孫要素の取得に関する情報が少なく、jqueryのような孫要素まで取得するメソッドもみつかりません。
何かいい方法がありましたらご教授いただければ幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは

CSSセレクタで要素を取得すればよいと思います。具体的には以下です。

python

1driver.find_element_by_css_selector('div > a:first-child')

以下は上記をテストするためのコード例です。

以下のようなHTMLを作成します。名前は test.html とします。

html

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <title>Test</title> 6</head> 7<body> 8 <div> 9 <div> 10 <a>A</a> 11 <div> 12 <div> 13 <div> 14 <a>B</a> 15 </div> 16 <div> 17 </div> 18 </div> 19 </div> 20 </div> 21 <div> 22 <div> 23 <div> 24 <a>C</a> 25 </div> 26 </div> 27 </div> 28 <div> 29 </div> 30 <a>D</a> 31 </div> 32</body> 33</html>

次に、上記の test.html と同じディレクトリに、以下のPythonスクリプトを作成します。

python

1from selenium import webdriver 2import os 3 4driver = webdriver.Chrome() 5driver.get('file://%s/test.html' % os.path.dirname(__file__)) 6 7a = driver.find_element_by_css_selector('div > a:first-child') 8 9print(a.text) 10 11driver.close()

上記のスクリプトは、 test.html をseleniumからのChromeで開いて、CSSセレクタ div > a:first-child で取得される <a> で囲まれたテキストを表示するもので、正常に実行されると

A

と表示されます。

以上参考になれば幸いです。

投稿2018/11/13 11:30

jun68ykt

総合スコア9058

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

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

navca

2018/11/13 12:31

ご丁寧にご説明頂きありがとうございました。目的の処理が達成できました。ありがとうございました。
jun68ykt

2018/11/13 17:43

解決されたようで、よかったです????
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問