Beautiful Soup 모듈을 사용하여 콘텐츠를 수정하기 위한 Python 샘플 코드에 대한 자세한 설명
Beautiful Soup은 HTML이나 XML 파일에서 데이터를 추출할 수 있는 Python 라이브러리입니다. 즐겨 사용하는 변환기를 통해 일반적인 방식으로 문서를 탐색하고 찾고 수정할 수 있습니다. 또한 HTML/XML 문서의 내용을 수정할 수도 있습니다. 이 글에서는 Python이 Beautiful Soup 모듈을 사용하여 내용을 수정하는 방법을 주로 소개합니다.
서문
실제로 Beautiful Soup 모듈은 검색 및 탐색 외에도 HTML/XML 문서의 내용을 수정할 수도 있습니다. 이는 태그 추가 또는 삭제, 태그 이름 수정, 태그 속성 값 변경, 텍스트 내용 수정 등이 가능함을 의미합니다. 이 기사에서는 Python이 Beautiful Soup 모듈을 사용하여 내용을 수정하는 방법을 자세히 소개합니다. 아래에서는 자세히 설명하지 않겠지만 자세한 소개를 살펴보겠습니다.
태그 수정
사용된 샘플 HTML 문서는 여전히 다음과 같습니다.
html_markup=""" <p class="ecopyramid"> <ul id="producers"> <li class="producerlist"> <p class="name">plants</p> <p class="number">100000</p> </li> <li class="producerlist"> <p class="name">algae</p> <p class="number">100000</p> </li> </ul> </p> """
태그 이름 수정
soup = BeautifulSoup(html_markup,'lxml') producer_entries = soup.ul print producer_entries.name producer_entries.name = "p" print producer_entries.prettify()
태그 속성 값 수정
# 修改标签属性 # 更新标签现有的属性值 producer_entries['id'] = "producers_new_value" print producer_entries.prettify() # 标签添加新的属性值 producer_entries['class'] = "newclass" print producer_entries.prettify() # 删除标签属性值 del producer_entries['class'] print producer_entries.prettify()
새 태그 추가
new_tag 메소드를 사용하여 새 태그를 생성한 다음 append()
, insert()
, insert_after()
, insert_before()
메서드를 사용하여 HTML 트리에 태그를 추가합니다.
예를 들어 위 HTML 문서의 ul 태그에 li 태그를 추가합니다. 먼저, 새로운 li 태그가 생성된 다음 HTML 트리 구조에 삽입됩니다. 그리고 li 태그에 해당 p 태그를 삽입합니다.
# 添加新的标签 # new_tag 生成一个 tag 对象 new_li_tag = soup.new_tag("li") # 标签对象添加属性的方法 new_atag = soup.new_tag("a",href="www.example.com" rel="external nofollow" ) new_li_tag.attrs = {'class':'producerlist'} soup = BeautifulSoup(html_markup,'lxml') producer_entries = soup.ul # 使用 append() 方法添加到末尾 producer_entries.append(new_li_tag) print producer_entries.prettify() # 生成两个 p 标签,将其插入到 li 标签中 new_p_name_tag = soup.new_tag("p") new_p_name_tag['class'] = "name" new_p_number_tag = soup.new_tag("p") new_p_number_tag["class"] = "number" # 使用 insert() 方法指定位置插入 new_li_tag.insert(0,new_p_name_tag) new_li_tag.insert(1,new_p_number_tag) print new_li_tag.prettify()
문자열 내용 수정
new_string()
, append()
, insert()
메서드를 사용하여 문자열 내용을 수정할 수 있습니다. .
# 修改字符串内容 # 使用 .string 属性修改字符串内容 new_p_name_tag.string = 'new_p_name' # 使用 .append() 方法添加字符串内容 new_p_name_tag.append("producer") # 使用 soup 对象的 new_string() 方法生成字符串 new_string_toappend = soup.new_string("producer") new_p_name_tag.append(new_string_toappend) # 使用insert() 方法插入 new_string_toinsert = soup.new_string("10000") new_p_number_tag.insert(0,new_string_toinsert) print producer_entries.prettify()
레이블 노드 삭제
Beautiful Soup 모듈은 노드를 삭제하는 decompose()
및 extract()
메소드를 제공합니다. 노드를 삭제하는
decompose()
메소드는 현재 노드뿐만 아니라 모든 하위 노드도 삭제합니다.
extract()
메소드는 HTML 트리에서 노드나 문자열 내용을 삭제하는 데 사용됩니다.
# 删除节点 third_producer = soup.find_all("li")[2] # 使用 decompose() 方法删除 p 节点 p_name = third_producer.p p_name.decompose() print third_producer.prettify() # 使用 extract() 方法删除节点 third_producer_removed = third_producer.extract() print soup.prettify()
태그 콘텐츠 삭제
태그에는 NavigableString 개체 또는 Tag 개체가 하위 노드로 포함될 수 있습니다. 이러한 모든 하위 노드를 제거하려면 clear()
메서드를 사용하세요. 이렇게 하면 태그에서 모든 .content가 제거됩니다.
다른 콘텐츠 수정 방법
위에서 언급한 방법 외에도 콘텐츠를 수정하는 다른 방법이 있습니다.
insert_after()
및 insert_before()
방법
위의 두 가지 방법은 레이블이나 문자열 앞이나 뒤에 레이블이나 문자열을 삽입할 수 있습니다. 메서드는 NavigableString 개체 또는 Tag 개체 중 하나의 매개 변수만 허용할 수 있습니다.
replace_with()
메서드
이 메서드는 원래 태그나 문자열을 새 태그나 문자열 콘텐츠로 대체하고 태그나 문자열을 입력으로 받을 수 있습니다.
wrap()
및 unwrap()
메서드
wrap()
메서드는 레이블이나 문자열을 다른 레이블로 래핑합니다.
unwrap()
방법은 wrap()
방법과 반대입니다.
위 내용은 Beautiful Soup 모듈을 사용하여 콘텐츠를 수정하기 위한 Python 샘플 코드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

Sublime 텍스트로 Python 코드를 실행하려면 먼저 Python 플러그인을 설치 한 다음 .py 파일을 작성하고 코드를 작성한 다음 CTRL B를 눌러 코드를 실행하면 콘솔에 출력이 표시됩니다.

Python은 부드러운 학습 곡선과 간결한 구문으로 초보자에게 더 적합합니다. JavaScript는 가파른 학습 곡선과 유연한 구문으로 프론트 엔드 개발에 적합합니다. 1. Python Syntax는 직관적이며 데이터 과학 및 백엔드 개발에 적합합니다. 2. JavaScript는 유연하며 프론트 엔드 및 서버 측 프로그래밍에서 널리 사용됩니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

Golang은 성능과 확장 성 측면에서 Python보다 낫습니다. 1) Golang의 컴파일 유형 특성과 효율적인 동시성 모델은 높은 동시성 시나리오에서 잘 수행합니다. 2) 해석 된 언어로서 파이썬은 천천히 실행되지만 Cython과 같은 도구를 통해 성능을 최적화 할 수 있습니다.

Visual Studio Code (VSCODE)에서 코드를 작성하는 것은 간단하고 사용하기 쉽습니다. vscode를 설치하고, 프로젝트를 만들고, 언어를 선택하고, 파일을 만들고, 코드를 작성하고, 저장하고 실행합니다. VSCODE의 장점에는 크로스 플랫폼, 무료 및 오픈 소스, 강력한 기능, 풍부한 확장 및 경량 및 빠른가 포함됩니다.

메모장에서 Python 코드를 실행하려면 Python 실행 파일 및 NPPEXEC 플러그인을 설치해야합니다. Python을 설치하고 경로를 추가 한 후 nppexec 플러그인의 명령 "Python"및 매개 변수 "{current_directory} {file_name}"을 구성하여 Notepad의 단축키 "F6"을 통해 Python 코드를 실행하십시오.
