>  기사  >  백엔드 개발  >  Selenium Python을 사용하여 섀도우 루트에서 데이터를 추출하는 방법은 무엇입니까?

Selenium Python을 사용하여 섀도우 루트에서 데이터를 추출하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-19 06:38:30962검색

How to Extract Data from a Shadow Root Using Selenium Python?

Selenium Python을 사용하여 섀도우 루트에서 정보 추출

제공된 URL https://www.tiendasjumbo.co/의 맥락에서 buscar?q=mani, #shadow-root(공개) 내의 요소에서 정보를 추출하는 것은 어려운 일입니다. 다음 코드 조각은 문제를 보여줍니다.

<code class="python">from selenium import webdriver
import time
from random import randint

driver = webdriver.Firefox(executable_path="C:\Program Files (x86)\geckodriver.exe")
driver.implicitly_wait(10)
time.sleep(4)

url = "https://www.tiendasjumbo.co/buscar?q=mani"
driver.maximize_window()
driver.get(url)
driver.find_element_by_xpath('//h1[@class="impulse-title"]')</code>

해결책:

웹 페이지 내의 제품은 섀도우 루트 내에 캡슐화됩니다. 이러한 요소에 액세스하려면 ShadowRoot.querySelector() 메서드를 사용해야 합니다. 다음 코드는 이 전략을 보여줍니다.

<code class="python">driver.get('https://www.tiendasjumbo.co/buscar?q=mani')
item = driver.execute_script("return document.querySelector('impulse-search').shadowRoot.querySelector('div.group-name-brand h1.impulse-title span.formatted-text')")
print(item.text)</code>

출력:

La especial mezcla de nueces, maní, almendras y marañones x 450 g

참조:

  • [Selenium 및 Python을 사용하여 #shadow-root(열기) 내에서 로그인 요소를 찾을 수 없습니다.](https://stackoverflow.com/questions/66779988/unable-to-locate-the-sign-in-element-within- Shadow-root-open-using-selenium-a)
  • [Selenium 및 Python을 사용하여 웹 사이트 https://www.virustotal.com 내의 Shadow-root(open)에서 이름 필드를 찾는 방법] (https://stackoverflow.com/questions/66820107/how-to-locate-the-first-name-field-within-shadow-root-open-within-the-website)

참고:

Microsoft Edge 및 Google Chrome 버전 96에서는 섀도우 루트 처리에 변경 사항이 도입되었습니다. 업데이트된 정보는 다음 리소스를 참조하세요.

  • Java: https://gist.github.com/chandrashekar4242/c2ef0878241f737cc89ec1878d60f974
  • Python: https://gist.github.com/hongtaocao/6409059fd2bb8d250f925b6b68c3a660
  • C#: https://gist.github.com/skcheidt/4a6a8bca561b403db94c7264a5a24 738
  • 루비: https://gist.github.com/yuusuke-tanaka1/3493c57d228f759be374aeb0b64e51d9

위 내용은 Selenium Python을 사용하여 섀도우 루트에서 데이터를 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:Python의 합계 유형다음 기사:Python의 합계 유형