Python BeautifulSoup

Python BeautifulSoup 简介 Python BeautifulSoup 安装 Python BeautifulSoup:根据 HTML 标签名获取元素 Python BeautifulSoup:根据 class 获取元素 Python BeautifulSoup:根据 id 获取元素 Python BeautifulSoup:使用 name 获取 HTML 标签名 Python BeautifulSoup:使用 get_text 获取 HTML 标签文本内容 Python BeautifulSoup:使用 attrs 处理 HTML 标签属性 Python BeautifulSoup:使用 decode_contents 获取 HTML 标签嵌套的 HTML 内容 Python BeautifulSoup:嵌套获取元素 Python BeautifulSoup:使用 find 和 find_all 查找元素 Python BeautifulSoup:使用 select_one 和 select 查找元素 Python BeautifulSoup:使用 append 追加内容 Python BeautifulSoup:使用 insert 插入内容 Python BeautifulSoup:使用 clear 清空内容 Python BeautifulSoup:设置内容 Python BeautifulSoup:使用 string 获取和设置 HTML 标签内容 Python BeautifulSoup:使用 extract 删除 HTML 标签 Python BeautifulSoup:使用 prettify 格式化 HTML Python BeautifulSoup:获取前后的同级元素 Python BeautifulSoup:使用 find_previous、find_next 获取当前元素前后的元素 Python BeautifulSoup:使用 find_parent 获取父元素 Python BeautifulSoup:使用 wrap 为元素增加父元素 Python BeautifulSoup 实战:去除 HTML 中的注释 Python BeautifulSoup 实战:去除 HTML 中的 script Python BeautifulSoup 实战:解析 oschina 首页内容 Python BeautifulSoup 实战:解析微信公众号文章列表 Python BeautifulSoup 实战:替换 href 属性内容

Python BeautifulSoup:设置内容


#Python BeautifulSoup


clear + insert/append

使用 clear + insert 或者 clear + append 可以达到 set 的效果。

示例:设置文本

from bs4 import BeautifulSoup

html_content = '''
<div id="content">
    <p>测试01</p>
    <span>测试02</span>
</div>
<div>测试03</div>
'''

soup = BeautifulSoup(html_content, 'html.parser')
print('------插入前-----')
print(soup)

content_div = soup.select_one("#content")
content_div.clear()
content_div.insert(0, '<p>插入</p>')  # 第1个参数是位置,第2个参数是内容
print('------插入后-----')
print(soup)

执行结果:

------插入前-----

<div id="content">
<p>测试01</p>
<span>测试02</span>
</div>
<div>测试03</div>

------插入后-----

<div id="content">&lt;p&gt;插入&lt;/p&gt;</div>
<div>测试03</div>


示例:设置 HTML 标签

from bs4 import BeautifulSoup

html_content = '''
<div id="content">
    <p>测试01</p>
    <span>测试02</span>
</div>
<div>测试03</div>
'''

soup = BeautifulSoup(html_content, 'html.parser')
print('------处理前-----')
print(soup)

content_div = soup.select_one("#content")
new_p = soup.new_tag('p')
new_p.string = '插入'
content_div.clear()
content_div.insert(0, new_p)  # 第1个参数是位置,第2个参数是内容
print('------处理后-----')
print(soup)

执行结果:

------处理前-----

<div id="content">
<p>测试01</p>
<span>测试02</span>
</div>
<div>测试03</div>

------处理后-----

<div id="content"><p>插入</p></div>
<div>测试03</div>

string

使用 string 属性可以获取和设置内容。

示例

from bs4 import BeautifulSoup

html_content = '''
<div id="content">
    <p>测试01</p>
    <span>测试02</span>
</div>
<div>测试03</div>
'''.strip()
soup = BeautifulSoup(html_content, 'html.parser')

content_div = soup.select_one("#content")
content_div.string = 'x<p>'
print(soup)

执行结果:

<div id="content">x&lt;p&gt;</div>
<div>测试03</div>

( 本文完 )