鱼C论坛

 找回密码
 立即注册
查看: 2032|回复: 4

[已解决]爬虫bs4和findall格式不通用

[复制链接]
发表于 2021-3-25 15:30:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 17623095765 于 2021-3-25 15:41 编辑
import requests
import bs4
import re
header={'ser-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36'}
wanzhi='http://top.baidu.com/buzz.php?p=book'
a=requests.get(wanzhi,headers=header)
b=bs4.BeautifulSoup(a.text,'html.parser')


bb=re.findall(r'<a class=".*?">(..)</a>',b)
print(bb)
return _compile(pattern, flags).findall(string)
TypeError: expected string or bytes-like object
type(b)
<class 'bs4.BeautifulSoup'>

如果直接用str(b) 会把数据变少
>>> b
Sqteezed text (1516 lines).
>>> str(b)
Sqteezed text (756 lines).
最佳答案
2021-3-25 18:16:14
本帖最后由 suchocolate 于 2021-3-25 18:20 编辑

正则,bs,xpath算是并列关系,用了正则就不用bs了,bs是已经对html文本做了结构话处理,就不能直接在用正则了。
import requests
import re

header = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64)'}
url = 'http://top.baidu.com/buzz.php?p=book'
r = requests.get(url, headers=header)
result = re.findall(r'<a class=".*?">(.*?)</a>', r.text)
print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-3-25 18:16:14 | 显示全部楼层    本楼为最佳答案   
本帖最后由 suchocolate 于 2021-3-25 18:20 编辑

正则,bs,xpath算是并列关系,用了正则就不用bs了,bs是已经对html文本做了结构话处理,就不能直接在用正则了。
import requests
import re

header = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64)'}
url = 'http://top.baidu.com/buzz.php?p=book'
r = requests.get(url, headers=header)
result = re.findall(r'<a class=".*?">(.*?)</a>', r.text)
print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-28 16:38:05 | 显示全部楼层
suchocolate 发表于 2021-3-25 18:16
正则,bs,xpath算是并列关系,用了正则就不用bs了,bs是已经对html文本做了结构话处理,就不能直接在用正 ...

再问一下哈,那么为何要用到BS4呢?或者说什么时候要BS4什么时候用re呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-28 16:54:51 | 显示全部楼层
17623095765 发表于 2021-3-28 16:38
再问一下哈,那么为何要用到BS4呢?或者说什么时候要BS4什么时候用re呢

re是比较暴力的提取,适合获取简单少量的数据场景,也适合在bs和xpath提取不到信息的jsavascript中。
bs或xpath相对来说比较智能,对html已做了结构化处理,提取复杂的信息更有效率。


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-28 21:52:19 | 显示全部楼层
suchocolate 发表于 2021-3-28 16:54
re是比较暴力的提取,适合获取简单少量的数据场景,也适合在bs和xpath提取不到信息的jsavascript中。
bs ...

好哒  谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 05:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表