아름다운 수프-문제 해결
오류 처리
BeautifulSoup에서 처리해야하는 두 가지 주요 오류가 있습니다. 이 두 오류는 BeautifulSoup API에서 오류가 발생하기 때문에 스크립트가 아니라 스 니펫 구조에서 발생합니다.
두 가지 주요 오류는 다음과 같습니다.
AttributeError
점 표기법이 현재 HTML 태그에 대한 형제 태그를 찾지 못할 때 발생합니다. 예를 들어, "anchor tag"누락으로 인해이 오류가 발생했을 수 있습니다. cost-key는 트래버스 할 때 오류를 발생시키고 앵커 태그가 필요합니다.
KeyError
이 오류는 필수 HTML 태그 속성이 누락 된 경우 발생합니다. 예를 들어 스 니펫에 data-pid 속성이없는 경우 pid 키는 키 오류를 발생시킵니다.
결과를 구문 분석 할 때 위의 두 가지 오류를 방지하기 위해 해당 결과는 무시되어 잘못된 스 니펫이 데이터베이스에 삽입되지 않도록합니다.
except(AttributeError, KeyError) as er:
pass
진단 ()
BeautifulSoup이 문서 나 HTML에 어떤 일을하는지 이해하는 데 어려움이있을 때마다이를 diagnostic () 함수에 전달하기 만하면됩니다. 문서 파일을 diagnostic () 함수에 전달할 때 다른 파서 목록이 문서를 처리하는 방법을 보여줄 수 있습니다.
아래는 diagnostic () 함수 사용을 보여주는 한 가지 예입니다.
from bs4.diagnose import diagnose
with open("20 Books.html",encoding="utf8") as fp:
data = fp.read()
diagnose(data)
산출
구문 분석 오류
파싱 오류에는 두 가지 주요 유형이 있습니다. BeautifulSoup에 문서를 공급할 때 HTMLParseError와 같은 예외가 발생할 수 있습니다. 또한 BeautifulSoup 구문 분석 트리가 구문 분석 문서의 예상 결과와 많이 다르게 보이는 예기치 않은 결과를 얻을 수도 있습니다.
파싱 오류는 BeautifulSoup으로 인해 발생하지 않습니다. BeautifulSoup에는 파서 코드가 포함되어 있지 않기 때문에 우리가 사용하는 외부 파서 (html5lib, lxml) 때문입니다. 위의 구문 분석 오류를 해결하는 한 가지 방법은 다른 구문 분석기를 사용하는 것입니다.
from HTMLParser import HTMLParser
try:
from HTMLParser import HTMLParseError
except ImportError, e:
# From python 3.5, HTMLParseError is removed. Since it can never be
# thrown in 3.5, we can just define our own class as a placeholder.
class HTMLParseError(Exception):
pass
Python 내장 HTML 파서는 가장 일반적인 두 가지 구문 분석 오류 인 HTMLParser.HTMLParserError : 잘못된 시작 태그 및 HTMLParser.HTMLParserError : 잘못된 끝 태그를 발생시킵니다.이 문제를 해결하려면 주로 lxml 또는 html5lib와 같은 다른 구문 분석기를 사용합니다.
또 다른 일반적인 유형의 예기치 않은 동작은 문서에서 알고있는 태그를 찾을 수 없다는 것입니다. 그러나 실행하면 find_all ()이 []를 반환하거나 find ()가 None을 반환합니다.
이것은 파이썬 내장 HTML 파서가 때때로 이해하지 못하는 태그를 건너 뛰기 때문일 수 있습니다.
XML 파서 오류
기본적으로 BeautifulSoup 패키지는 문서를 HTML로 구문 분석하지만, 매우 사용하기 쉽고 beautifulsoup4를 사용하여 매우 우아한 방식으로 형식이 잘못된 XML을 처리합니다.
문서를 XML로 구문 분석하려면 lxml 파서가 있어야하며 Beautifulsoup 생성자에 두 번째 인수로 "xml"을 전달하면됩니다.
soup = BeautifulSoup(markup, "lxml-xml")
또는
soup = BeautifulSoup(markup, "xml")
일반적인 XML 구문 분석 오류는 다음과 같습니다.
AttributeError: 'NoneType' object has no attribute 'attrib'
find () 또는 findall () 함수를 사용하는 동안 일부 요소가 없거나 정의되지 않은 경우에 발생할 수 있습니다.
기타 구문 분석 오류
다음은이 섹션에서 논의 할 다른 파싱 오류 중 일부입니다.
환경 문제
위에서 언급 한 구문 분석 오류 외에도 스크립트가 한 운영 체제에서는 작동하지만 다른 운영 체제에서는 작동하지 않거나 한 가상 환경에서는 작동하지만 다른 가상 환경에서는 작동하지 않거나 작동하지 않는 환경 문제와 같은 다른 구문 분석 문제가 발생할 수 있습니다. 가상 환경 외부. 이러한 모든 문제는 두 환경에서 사용 가능한 파서 라이브러리가 다르기 때문일 수 있습니다.
현재 작업 환경에서 기본 파서를 확인하거나 확인하는 것이 좋습니다. 현재 작업 환경에서 사용 가능한 현재 기본 파서를 확인하거나 필요한 파서 라이브러리를 BeautifulSoup 생성자에 두 번째 인수로 명시 적으로 전달할 수 있습니다.
대소 문자 구분 안함
HTML 태그 및 속성은 대소 문자를 구분하지 않으므로 세 HTML 파서 모두 태그 및 속성 이름을 소문자로 변환합니다. 그러나 대 / 소문자가 혼합 된 태그 및 속성을 유지하려면 문서를 XML로 구문 분석하는 것이 좋습니다.
UnicodeEncodeError
아래 코드 세그먼트를 살펴 보겠습니다.
soup = BeautifulSoup(response, "html.parser")
print (soup)
산출
UnicodeEncodeError: 'charmap' codec can't encode character '\u011f'
위의 문제는 두 가지 주요 상황 때문일 수 있습니다. 콘솔에서 표시하는 방법을 모르는 유니 코드 문자를 인쇄하려고 할 수 있습니다. 둘째, 파일에 쓰기를 시도하고 기본 인코딩에서 지원하지 않는 유니 코드 문자를 전달합니다.
위의 문제를 해결하는 한 가지 방법은 다음과 같이 원하는 결과를 얻기 위해 수프를 만들기 전에 응답 텍스트 / 문자를 인코딩하는 것입니다.
responseTxt = response.text.encode('UTF-8')
KeyError : [attr]
문제의 태그가 attr 속성을 정의하지 않는 경우 tag [ 'attr']에 액세스하여 발생합니다. 가장 일반적인 오류는 "KeyError : 'href'"및 "KeyError : 'class'"입니다. attr이 정의되어 있는지 확실하지 않은 경우 tag.get ( 'attr')을 사용하십시오.
for item in soup.fetch('a'):
try:
if (item['href'].startswith('/') or "tutorialspoint" in item['href']):
(...)
except KeyError:
pass # or some other fallback action
AttributeError
다음과 같이 AttributeError가 발생할 수 있습니다-
AttributeError: 'list' object has no attribute 'find_all'
위의 오류는 주로 find_all ()이 단일 태그 또는 문자열을 반환 할 것으로 예상했기 때문에 발생합니다. 그러나 soup.find_all은 요소의 파이썬 목록을 반환합니다.
해야 할 일은 목록을 반복하고 해당 요소에서 데이터를 포착하는 것입니다.