BeautifulSoup을 사용하여 HTML을 구문 분석할 때 다음과 같은 문제가 발생할 수 있습니다. NoneType 개체와 관련된 결과 또는 AttributeError 예외가 없습니다. 이는 구문 분석된 데이터에서 특정 요소나 속성을 찾을 수 없을 때 발생합니다.
BeautifulSoup은 단일 결과 쿼리와 다중 결과 쿼리를 모두 제공합니다. 여러 결과를 지원하는 .find_all과 같은 메서드는 일치하는 요소가 없으면 빈 목록을 반환합니다.
그러나 단일 결과를 기대하는 .find 및 .select_one과 같은 메서드는 일치하는 요소가 없으면 None을 반환합니다. 이는 대신 예외가 발생할 수 있는 다른 프로그래밍 언어와는 다릅니다.
단일 결과 메서드에서 None 결과로 작업할 때 AttributeError 오류를 방지하려면:
질문의 코드 예를 고려하세요.
print(soup.sister) # Returns None because no <sister> tag exists print(soup.find('a', class_='brother')) # Returns None because no <a> tag with class="brother" exists print(soup.select_one('a.brother')) # Returns None, same reason as above soup.select_one('a.brother').text # Throws AttributeError because 'None' has no 'text' attribute
이러한 시나리오를 올바르게 처리하려면 다음 기술을 사용하세요.
if soup.sister is not None: print(soup.sister.name) # Safely accesses the tag name try: print(soup.find('a', class_='brother').text) except AttributeError: print("No 'brother' class found") # Catches the potential error brother_text = soup.select_one('a.brother') or "Brother not found" # Assigns a default value if not found
이러한 지침을 따르면 BeautifulSoup를 사용하여 HTML을 구문 분석할 때 AttributeError 예외를 방지하고 None 결과를 효과적으로 처리할 수 있습니다.
위 내용은 BeautifulSoup이 때때로 None을 반환하는 이유는 무엇이며 AttributeError를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!