>백엔드 개발 >파이썬 튜토리얼 >BeautifulSoup에서 XPath를 어떻게 사용할 수 있나요?

BeautifulSoup에서 XPath를 어떻게 사용할 수 있나요?

Linda Hamilton
Linda Hamilton원래의
2024-11-08 06:26:01736검색

How can I use XPath with BeautifulSoup?

BeautifulSoup과 함께 XPath 사용

BeautifulSoup은 HTML 문서를 구문 분석하고 조작하는 데 널리 사용되는 Python 라이브러리입니다. 그러나 기본적으로 XPath 표현식을 지원하지 않습니다.

대안: lxml

lxml이라는 대체 라이브러리는 완전한 XPath 1.0 지원을 제공합니다. 또한 BeautifulSoup처럼 손상된 HTML을 구문 분석할 수 있는 BeautifulSoup 호환 모드도 있습니다. lxml과 함께 XPath를 사용하려면:

from lxml import etree
from urllib import request

url = "http://www.example.com/servlet/av/ResultTemplate=AVResult.html"
response = request.urlopen(url)
tree = etree.parse(response, etree.HTMLParser())
result_list = tree.xpath("/html/body/div/table/tbody/tr[1]/td[1]")

lxml과 함께 CSS 선택기 사용

lxml에는 CSS 문을 XPath 표현식으로 변환할 수 있는 CSSSelector 지원도 있습니다. 예를 들어, empformbody 클래스를 사용하여 td 요소를 찾으려면:

from lxml.cssselect import CSSSelector

css_selector = CSSSelector('td.empformbody')
result_list = css_selector(tree)

BeautifulSoup의 CSS 선택기

흥미롭게도 BeautifulSoup에는 자체 CSS 선택기 지원이 있습니다.

soup = BeautifulSoup(html, "html.parser")
result_list = soup.select('table#foobar td.empformbody')

위 내용은 BeautifulSoup에서 XPath를 어떻게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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