Python에서 Selenium WebDriver를 사용하여 텍스트 요소에 액세스
Selenium WebDriver를 사용하는 웹 자동화에서는 HTML 요소에서 텍스트 콘텐츠를 검색하는 것이 필수적입니다. 그러나 제시된 경우처럼 페이지를 다시 로드할 때 요소의 ID가 동적으로 변경되면 문제가 발생할 수 있습니다.
원본 코드
제공된 원본 코드:
text = driver.find_element_by_class_name("current-stage").getText("my text")
클래스 이름 "현재 단계"로 요소를 찾고 "내 텍스트"로 예상되는 해당 텍스트를 추출하려고 시도합니다.
HTML 구조
제공된 HTML 구조는 다음과 같이 클래스 이름이 "current-text"이고 동적 ID가 있는 텍스트 요소를 보여줍니다.
<span class="current-text" id="yui_3_7_0_4_1389185744113_384">my text</span>
문제
원본 코드의 문제는 XPath와 관련된 것이 아니라 getText 메소드의 오용과 관련이 있습니다. getText에 인수를 전달하면 요소의 텍스트를 검색하는 것이 아니라 설정하려고 시도합니다.
올바른 접근 방식
요소에서 텍스트를 추출하는 올바른 접근 방식은 다음과 같습니다. 다음과 같이 인수 없이 getText를 사용합니다.
text = driver.find_element_by_class_name("current-stage").getText()
이 코드는 요소의 텍스트 콘텐츠를 검색하여 텍스트 변수에 저장합니다.
결과 확인
예상 텍스트를 getText 메소드에 전달하는 대신 다음과 같이 나중에 AssertEqual 메소드를 사용하여 검색된 텍스트를 확인할 수 있습니다.
expected_text = "my text" actual_text = driver.find_element_by_class_name("current-stage").getText() self.assertEqual(expected_text, actual_text)
이 접근 방식은 검색된 텍스트가 예상값과 일치합니다.
위 내용은 Selenium WebDriver에서 동적으로 변경되는 HTML 요소에서 텍스트를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!