【好久不用bs4,手都生了】复习一点点bs4的用法

本文通过复习《Python网络数据采集》一书的基础章节并结合实际案例,介绍了如何使用Python进行网页数据抓取。具体实现中利用了urllib库来打开网页链接,并采用BeautifulSoup解析HTML内容,最终获取到了目标网站的所有段落文本。

主要是复习《Python网络数据采集》的基础章节,参考了imooc站老师的一些代码,用到漂亮汤了我竟然不会写了。最后的代码如下:

from urllib.request import urlopen    #需要urlopen打开链接,BeautifulSoup解析Html
from bs4 import BeautifulSoup

class Spider():
    
    def get_html(self):
        html = urlopen("https://zh.moegirl.org/zh-cn/Mainpage")    #萌娘百科简中首页
        return html
    
if __name__ == "__main__":
    spider = Spider()
    bs = BeautifulSoup(spider.get_html(), 'html.parser', from_encoding='utf-8')

    #找出首页所有<p>标签内容,并最终只取其文本内容
    findHtmls = bs.findAll('p')
#   print(findHtmls.get_text())    错误,List对象没有get_text()
    for html in findHtmls:
        print(html.get_text())
    
    #保存了整个html页面
    f = open('go.html','w')
    f.write(str(spider.get_html().read(),'utf-8'))
    f.close()
    
    print('done')

其间遇到了一个问题就是不知道怎么打印出findAll得到的内容,后来翻书发现findAll的返回是一个List……囧……

以后一定要记得了:

find返回的是字符串;

findAll返回的是字符串们的列表。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值