爬虫beautifulsoup 使用信安培训2019年5月25日
beautifulsoup
beautifulsoup安装
data:image/s3,"s3://crabby-images/ef67b/ef67b02340073ceee196c4740a7c4aa341da6eb5" alt="CMD命令行pip安装beautifulsoup4库 CMD命令行pip安装beautifulsoup4库"
CMD命令行pip安装beautifulsoup4库
学习样例题目
题目地址
data:image/s3,"s3://crabby-images/da852/da85225b137154ea1e4166b1f301a8a71f0ee070" alt="题目截图 题目截图"
题目截图
解题步骤
beautifulsoup 快速讲解
查看源代码
data:image/s3,"s3://crabby-images/4940a/4940ae37921590e0c9e27978d8dc843babb7d87f" alt="算式位置在p标签中 name=‘myexpr’的div中 算式位置在p标签中 name=‘myexpr’的div中"
算式位置在p标签中 name=‘myexpr’的div中
代码
import requests
from bs4 import BeautifulSoup
r = requests.get('http://ctf5.shiyanbar.com/jia/index.php')
r.encoding = r.apparent_encoding
soup = BeautifulSoup(r.text,'html.parser')
a = soup.find_all('div',{"name":"my_expr"})
data:image/s3,"s3://crabby-images/4fee4/4fee4ebed009b12fb35b58a8a354cdf719a4e9ac" alt="匹配相应数据 匹配相应数据"
匹配相应数据
代码2
只有一个p标签
所以可以直接这么使用直接匹配p
b=soup.p.div.get_text()
例题二爬取中国大学排名
解析出排名和大学名称即可
data:image/s3,"s3://crabby-images/df4aa/df4aa32783c17a413be5e326e913c2e0fa9d9971" alt="大学排名网站 大学排名网站"
大学排名网站
from bs4 import BeautifulSoup
import requests
r = requests.get('http://www.zuihaodaxue.cn/zuihaodaxuepaiming2019.html')
r.encoding = r.apparent_encoding
attr = {"class":"table table-small-font table-bordered table-striped"}
soup = BeautifulSoup(r.text,'html.parser')
a = soup.find('table',attr)
a = a.find_all('tr',{"class":"alt"})
result = '排名,大学
'
for i in a:
result += i('td')[0].text +','+i.div.text+'
'
with open('rank.csv','w') as f:
f.write(result)