トップページ > Selenium API(逆引き) > 【Java】deselectByVisibleText

【Java】deselectByVisibleText・・・セレクトタグのオプションをテキストを指定して未選択にする

【PR】業界トップクラスの「高単価報酬」「低マージン」を実現!レバテックフリーランス

Selectクラスのインスタンスに対して「deselectByVisibleText」を実行することで、セレクトタグのオプションをテキスト指定で未選択することが出来ます。

下記のサンプルでは、まずSelectクラスのインスタンスを取得するために、Selectクラスのコンストラクタの引数に、セレクトタグの要素を指定しています。続いて取得したインスタンスに対して「selectByIndex」を実行することで先頭3つのオプションを選択状態にしています。最後に「deselectByVisibleText」の引数にテキストを指定することで、指定されたテキストに一致するオプションを未選択状態にしています。

説明

◆メソッド
  ・public void deselectByVisibleText(java.lang.String text)
◆使用形態
  ・select.deselectByVisibleText(textName)
◆備考
  ・指定されたテキストが存在しない場合はExceptionが発生する
◆関連項目
  ・要素に入力された値をクリアする
  ・要素をクリックする

サンプル

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.Select;

public class WebTest{
  public static void main(String[] args){
    //Chrome制御のためChromeDriverのパスを指定
	System.setProperty("webdriver.chrome.driver",
		                            "D:\\AutoTest\\chromedriver.exe");
    //Chromeを起動する
    WebDriver driver = new ChromeDriver();
    //指定したURLに遷移する<図1>
    driver.get("file://D:/AutoTest/Select.html");
    //要素をid番号から取得する(idが002のセレクトタグ)
    WebElement element = driver.findElement(By.id("002"));
    //セレクトタグの要素を指定してSelectクラスのインスタンスを作成
    Select select = new Select(element);
    //12星座の先頭から3つ連続を選択状態にする
    for(int i=0;i<3;i++){
        select.selectByIndex(i);
    }
    //先頭から3つ連続が選択状態になっていることをWaitをおいて確認する
    try{
        Thread.sleep(3000);
        }catch(InterruptedException e){
        }
    //指定するテキストを設定する
    String text = "Aries";
    //テキストで指定したオプションを未選択にする
    select.deselectByVisibleText(text);
  }
}
※selenium version 4.1.4で動作確認をしています

実行結果

deselectByVisibleText
yajirushi
deselectByVisibleText2

Select.html<図1>

<!DOCTYPE html>
<html lang="ja">
    <head>
        <title>Select</title>
    </head>
    <body>
        <article>
            <p>血液型:<br>
                <select name="blood" id="001">
                    <option value="A">A type</option>
                    <option value="B">B type</option>
                    <option value="O">O type</option>
                    <option value="AB">AB type</option>
                </select>
            </p>
            <p>星座:<br>
                <select name="horoscope" size="12"multiple id="002">
                    <option value="Ari">Aries</option>
                    <option value="Tau">Taurus</option>
                    <option value="Gem">Gemini</option>
                    <option value="Can">Cancer</option>
                    <option value="Leo">Leo</option>
                    <option value="Vir">Virgo</option>
                    <option value="Lib">Libra</option>
                    <option value="Sco">Scorpio</option>
                    <option value="Sag">Saggitarius</option>
                    <option value="Cap">Capricorn</option>
                    <option value="Aqu">Aquarius</option>
                    <option value="Pis">Pisces</option>
                </select>
            </p>
        </article>
    </body>
</html>

動画デモ

※字幕をONにすると解説のテロップが表示されます※


Fatal error: Uncaught Google_Service_Exception: Error calling GET https://www.googleapis.com/analytics/v3/data/ga?ids=ga%3A138132118&start-date=7daysAgo&end-date=yesterday&metrics=ga%3Apageviews&dimensions=ga%3ApageTitle%2C+ga%3ApagePath&sort=-ga%3Apageviews&max-results=1000: (404) <!DOCTYPE html> <html lang=en> <meta charset=utf-8> <meta name=viewport content="initial-scale=1, minimum-scale=1, width=device-width"> <title>Error 404 (Not Found)!!1</title> <style> *{margin:0;padding:0}html,code{font:15px/22px arial,sans-serif}html{background:#fff;color:#222;padding:15px}body{margin:7% auto 0;max-width:390px;min-height:180px;padding:30px 0 15px}* > body{background:url(//www.google.com/images/errors/robot.png) 100% 5px no-repeat;padding-right:205px}p{margin:11px 0 22px;overflow:hidden}ins{color:#777;text-decoration:none}a img{border:0}@media screen and (max-width:772px){body{background:none;margin-top:0;max-width:none;padding-right:0}}#logo{background:url(//www.google.com/images/branding/googlelogo/1x/googlelogo_c in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110