セレンを使用してテキストで元素を見つける方法

How Find Element Text With Selenium



Webページから要素を見つけて選択することは、Seleniumを使用したWebスクレイピングの鍵です。 Seleniumでは、タグ名、ID、クラス名、XPathセレクター、CSSセレクターなどを使用して要素を選択できます。 Seleniumで特定のテキストを持つ要素を選択することもできます。これは、Webページからリンクやボタンを簡単に選択するのに役立ちます。ページ構造が変更されても、Webページ要素のテキストが同じである限り、セレクターは正常に機能するはずです。これは、Seleniumのテキストを使用してリンクとボタンを選択する利点です。

この記事では、SeleniumPythonライブラリでSeleniumのテキストを使用してWebページから要素を見つけて選択する方法を紹介します。それでは、始めましょう。







前提条件:

この記事のコマンドと例を試すには、次のものが必要です。



  1. コンピューターにインストールされているLinuxディストリビューション(できればUbuntu)。
  2. コンピューターにインストールされているPython3。
  3. コンピューターにインストールされているPIP3。
  4. Python virtualenv コンピュータにインストールされているパッケージ。
  5. コンピュータにインストールされているMozillaFirefoxまたはGoogleChromeWebブラウザ。
  6. Firefox GeckoDriverまたはChromeWebDriverのインストール方法を知っている必要があります。

要件4、5、および6を満たすために、私の記事を読んでください Python3でのSeleniumの概要



あなたは他のトピックに関する多くの記事を見つけることができます LinuxHint.com 。サポートが必要な場合は、必ずチェックしてください。





プロジェクトディレクトリの設定:

すべてを整理するには、新しいプロジェクトディレクトリを作成します セレン-テキスト-選択/ 次のように:

$mkdir -pvセレン-テキスト-選択/運転手



に移動します セレン-テキスト-選択/ 次のようにプロジェクトディレクトリ:

$CDセレン-テキスト-選択/

次のように、プロジェクトディレクトリにPython仮想環境を作成します。

$virtualenv .venv

次のように仮想環境をアクティブ化します。

$ソース.venv/午前/活性化

次のように、PIP3を使用してSeleniumPythonライブラリをインストールします。

$ pip3インストールセレン

必要なすべてのWebドライバーをダウンロードしてインストールします。 運転手/ プロジェクトのディレクトリ。私の記事でWebドライバーをダウンロードしてインストールするプロセスを説明しました Python3でのSeleniumの概要

テキストによる要素の検索:

このセクションでは、SeleniumPythonライブラリを使用してテキストでWebページ要素を検索および選択する例をいくつか紹介します。

テキストでWebページの要素を選択し、Webページからリンクを選択する最も簡単な例から始めます。

facebook.comのログインページにリンクがあります アカウントを忘れましたか? 下のスクリーンショットでわかるように。 Seleniumでこのリンクを選択しましょう。

新しいPythonスクリプトを作成する ex01.py 次のコード行を入力します。

からセレン輸入webdriver
からセレン。webdriver一般キー 輸入キー
からセレン。webdriver一般 輸入
から 時間 輸入寝る
ブラウザ=webdriver。クロム((実行可能パス='./drivers/chromedriver')。
ブラウザ。得る((「https://www.facebook.com/」)。
forgotAccountLink=ブラウザ。find_element((に。XPATH '
// * [text()= 'アカウントを忘れましたか?'] '
)。
forgotAccountLink。send_keys((キー。入力)。

完了したら、 ex01.py Pythonスクリプト。

1〜4行目では、必要なすべてのコンポーネントをPythonプログラムにインポートしています。

6行目はChromeを作成します ブラウザ を使用するオブジェクト chromedriver からのバイナリ 運転手/ プロジェクトのディレクトリ。

8行目は、ブラウザにWebサイトfacebook.comをロードするように指示しています。

10行目は、テキストを含むリンクを見つけます アカウントを忘れましたか? XPathセレクターを使用します。そのために、私はXPathセレクターを使用しました // * [text()= 'アカウントを忘れましたか?']

XPathセレクターはで始まります //、 つまり、要素はページのどこにあってもかまいません。 NS * 記号は、Seleniumに任意のタグを選択するように指示します( また NS また スパン、 など)角括弧内の条件に一致する [] 。ここでの条件は、要素のテキストが次の値に等しいことです。 アカウントを忘れましたか?

NS 文章() XPath関数は、要素のテキストを取得するために使用されます。

例えば、 文章() 戻り値 こんにちは世界 次のHTML要素を選択した場合。

< href=「http://dummysite.com」>>こんにちは世界</ >>

11行目は キーを押して アカウントを忘れましたか? リンク。

Pythonスクリプトを実行する ex01.py 次のコマンドを使用します。

$ pythonex01。py

ご覧のとおり、Webブラウザーは、 のキー アカウントを忘れましたか? リンク。

NS アカウントを忘れましたか? リンクをクリックすると、ブラウザは次のページに移動します。

同様に、目的の属性値を持つ要素を簡単に検索できます。

ここでは、 ログインする ボタンは 入力 を持っている要素 価値 属性 ログインする 。この要素をテキストで選択する方法を見てみましょう。

新しいPythonスクリプトを作成する ex02.py 次のコード行を入力します。

からセレン輸入webdriver
からセレン。webdriver一般キー 輸入キー
からセレン。webdriver一般 輸入
から 時間 輸入寝る
ブラウザ=webdriver。クロム((実行可能パス='./drivers/chromedriver')。
ブラウザ。得る((「https://www.facebook.com/」)。
寝る((5)。
emailInput=ブラウザ。find_element((に。XPATH '// input [@ id =' email ']')。
passwordInput=ブラウザ。find_element((に。XPATH '// input [@ id =' pass ']')。
loginButton=ブラウザ。find_element((に。XPATH '// * [@ value ='ログイン ']')。
emailInput。send_keys(('[メール保護]')。
寝る((5)。
passwordInput。send_keys((「シークレットパス」)。
寝る((5)。
loginButton。send_keys((キー。入力)。

完了したら、 ex02.py Pythonスクリプト。

1〜4行目は、必要なすべてのコンポーネントをインポートします。

6行目はChromeを作成します ブラウザ を使用するオブジェクト chromedriver からのバイナリ 運転手/ プロジェクトのディレクトリ。

8行目は、ブラウザにWebサイトfacebook.comをロードするように指示しています。

スクリプトを実行すると、すべてが非常に高速に実行されます。だから、私は使用しました 寝る() で何度も機能する ex02.py ブラウザコマンドを遅らせるため。このようにして、すべてがどのように機能するかを観察できます。

11行目は、電子メール入力テキストボックスを検索し、要素の参照を emailInput 変数。

12行目は、電子メール入力テキストボックスを検索し、要素の参照を emailInput 変数。

13行目は、属性を持つ入力要素を見つけます 価値ログインする XPathセレクターを使用します。そのために、私はXPathセレクターを使用しました // * [@ value = ’ログイン’]

XPathセレクターはで始まります // 。これは、要素がページのどこにあってもよいことを意味します。 NS * 記号は、Seleniumに任意のタグを選択するように指示します( 入力 また NS また スパン、 など)角括弧内の条件に一致する [] 。ここで、条件は、要素属性です。 価値 に等しい ログインする

15行目は入力を送信します[メール保護]電子メール入力テキストボックスに移動し、16行目で次の操作を遅らせます。

18行目は入力シークレットパスをパスワード入力テキストボックスに送信し、19行目は次の操作を遅らせます。

21行目は キーを押してログインボタンを押します。

を実行します ex02.py 次のコマンドを使用したPythonスクリプト:

$ python3ex02。py

ご覧のとおり、メールとパスワードのテキストボックスにはダミーの値が入力されており、 ログインする ボタンが押されました。

次に、ページは次のページに移動します。

部分的なテキストによる要素の検索:

前のセクションでは、特定のテキストで要素を見つける方法を示しました。このセクションでは、部分的なテキストを使用してWebページから要素を見つける方法を紹介します。

例では、 ex01.py 、テキストを含むリンク要素を検索しました アカウントを忘れましたか? 。次のような部分的なテキストを使用して、同じリンク要素を検索できます。 忘れられたacc 。これを行うには、 contains() の10行目に示されているXPath関数 ex03.py 。残りのコードはと同じです ex01.py 。結果は同じになります。

の10行目 ex03.py 、使用した選択条件 含む(ソース、テキスト) XPath関数。この関数は2つの引数を取ります。 ソース、文章

NS contains() 関数は、 文章 2番目の引数で指定されたものは部分的に一致します ソース 最初の引数の値。

ソースは要素のテキストにすることができます( 文章() )または要素の属性値( @attr_name )。

ex03.py 、要素のテキストがチェックされます。

部分的なテキストを使用してWebページから要素を検索するためのもう1つの便利なXPath関数は次のとおりです。 開始-with(ソース、テキスト) 。この関数には、 contains() 機能し、同じように使用されます。唯一の違いは、 開始-with() 関数は、2番目の引数が 文章 最初の引数の開始文字列です ソース

例を書き直しました ex03.py テキストがで始まる要素を検索するには 忘れて、 の10行目にあるように ex04.py 。結果はと同じです ex02ex03.py

私も書き直しました ex02.py そのため、入力要素を検索します。 価値 属性はで始まります ログ、 の13行目にあるように ex05.py 。結果はと同じです ex02.py

結論:

この記事では、SeleniumPythonライブラリを使用してテキストでWebページから要素を検索および選択する方法を示しました。これで、Selenium Pythonライブラリを使用して、特定のテキストまたは部分的なテキストでWebページから要素を見つけることができるはずです。