笔记001:BeautifulSoup中的find_all和re.findall区别

1.使用re.findall('<div id="content">(.*?)</div>',requests1_html.content.decode('gbk'),re.S)

down_dz = 'https://XXXXXXX.html'
headers = {'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:105.0) Gecko/20100101 Firefox/105.0'}
requests1_html = requests.get(down_dz, headers=headers)
requests1_html.encoding = 'gbk'
contents = re.findall('<div id="content">(.*?)</div>',requests1_html.content.decode('gbk'),re.S)
for content in contents:
    content = str(content).replace('<br />', '')
    content = str(content).replace('&nbsp;', '')
    print(content)
    with open('file/test01.txt','a+',encoding='gbk') as test1:
        test1.write(content)

注意:content前面要加上str(),做转换

 运行结果是

 2.使用BeautifulSoup中的find_all也可以达到异曲同工的效果

down_dz = 'https://XXXXXXX.html'
headers = {'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:105.0) Gecko/20100101 Firefox/105.0'}
requests1_html = requests.get(down_dz, headers=headers)
requests1_html.encoding = 'gbk'
soup1 = BeautifulSoup(requests1_html.text, "lxml")
# print(soup1)
for link1 in soup1.find_all(id="content"):
    link1 = str(link1).replace('<br>', '')
    link1 = link1.replace('<br/>\n', '')
    link1 = link1.replace('<br/>', '')
    link1 = link1.replace('<div id="content">', '')
    link1 = link1.replace(('</div>'), '')
    print(link1)

感觉要多几行代码,运行结果如下

注意: for link1 in soup1.find_all(id="content"):

这个是关键

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值