> 백엔드 개발 > 파이썬 튜토리얼 > Selenium WebDriver에서 동적으로 변경되는 HTML 요소에서 텍스트를 검색하는 방법은 무엇입니까?

Selenium WebDriver에서 동적으로 변경되는 HTML 요소에서 텍스트를 검색하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-03 04:36:03
원래의
1031명이 탐색했습니다.

How to Retrieve Text from Dynamically Changing HTML Elements in Selenium WebDriver?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿