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

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

Linda Hamilton
풀어 주다: 2024-11-08 06:26:01
원래의
702명이 탐색했습니다.

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

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