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