BeautifulSoup으로 속성 값 추출: Python에서 TypeError 해결
웹페이지의 특정 "입력" 태그에 대해 BeautifulSoup을 호출하기로 결정했습니다. 다음 코드를 사용하여 임무를 시작했습니다.
import urllib f = urllib.urlopen("http://58.68.130.147") s = f.read() f.close() from BeautifulSoup import BeautifulStoneSoup soup = BeautifulStoneSoup(s) inputTag = soup.findAll(attrs={"name": "stainfo"}) output = inputTag['value'] print str(output)
그러나 수수께끼의 TypeError: 목록 인덱스는 str이 아닌 정수여야 합니다. BeautifulSoup 문서에서 위안을 구하면서 절망이 스며들었지만 그 복잡함으로 인해 혼란스러워졌습니다. 이 수수께끼를 밝혀 보겠습니다.
find_all() 메서드는 일치하는 모든 요소의 목록을 반환합니다. 귀하의 경우 input_tag는 하나의 요소만 포함하는 목록입니다. 후속 라인인 output = inputTag['value']는 목록의 첫 번째 요소와 연관된 사전의 값에 액세스하려고 시도합니다. 목록 인덱스는 정수여야 하므로 보고된 오류와 함께 이 작업이 실패합니다.
문제를 해결하려면 다음 두 가지 옵션이 있습니다.
옵션 1: 첫 번째 요소 선택
다음을 사용하여 목록에서 첫 번째 요소를 명시적으로 선택합니다. 색인 생성:
input_tag = soup.find_all(attrs={"name": "stainfo"}) output = input_tag[0]['value']
옵션 2: find() 메서드 사용
첫 번째로 일치하는 요소만 반환하는 find() 메서드 활용:
input_tag = soup.find(attrs={"name": "stainfo"}) output = input_tag['value']
이러한 접근 방식 중 하나를 구현하면 원하는 속성 값을 효과적으로 추출하고 추가 작업 없이 BeautifulSoup 여정을 계속할 수 있습니다. 장애물.
위 내용은 TypeError를 해결하는 방법: BeautifulSoup로 속성 값을 추출할 때 목록 인덱스는 str이 아닌 정수여야 합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!