Python网络数据采集笔记.docxVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Python网络数据采集笔记

BeautifulSoup简介from urllib.request import urlopenfrom bs4 import BeautifulSouphtml = urlopen()#打开一个网址bsObj = BeautifulSoup(html.read(),html.parser)#建立了一个美丽汤对象,以网页内容为参数#调用html.read获取网页的HTML内容#这样就可以把HTML内容传到美丽汤对象print (bsObj.h1) #提取h1标签导入urlopen,然后调用html.read()获取网页的HTML内容,这样就可以把HTML内容传到BeautifulSoup对象用bsObj.h1从对象里提取h1标签任何HTML文件的任意节点的信息都可以被提取出来处理异常html = urlopen(/pages/page1.html)这一句可能出现两种异常:网页在服务器上不存在(提取网页时出现错误)——返回HTTP错误,urlopen函数抛出HTTPError异常处理:try: html = urlopen(/pages/page1.html) except HTTPError as e: print(e)#返回空值,中断程序,或者执行另一个方案 else: #程序继续服务器不存在(连接打不开、写错了),urlopen就会返回一个None对象,可以增加一个判断语句检测返回的html是不是None:if html is None:print(‘URL is not found’)else: #程序继续第一个爬虫:from urllib.request import urlopenfrom urllib.error import HTTPError,URLErrorfrom bs4 import BeautifulSoupdef getTitle(url): try: html = urlopen(url) except (HTTPError,URLError) as e: return None try:bsObj = BeautifulSoup(html.read(),html.parser) title = bsObj.html.head.title except AttributeError as e: return None return titletitle = getTitle(/#signin)if title == None: print(title could not be found)else: print(title)复杂HTML解析/pages/warandpeace.html抓出整个页面,然后创建一个BeautifulSoup对象:from urllib.request import urlopenfrom bs4 import BeautifulSouphtml = urlopen(‘/pages/warandpeace.html’)bsObj = BeautifulSoup(html)通过BeautifulSoup对象,可以用findAll函数抽取只包含在某个标签里的文字,如:namelist = bsObj.findAll(‘span’,{‘class’:’green’})for name in namelist: print(name.get_text()) #得到一个包含人物名称的Python列表find()与findAll()函数findAll(tag,attributes,recursive,text,limit,keywords)find(tag, attributes,recursive,text,keywords)tag——传一个或多个标签的名称组成的列表做标签函数,例如:.findAll({‘h1’,’h2’,’h3’,’h4’,’h5’})attributes——用一个Python字典封装一个标签的若干属性和对应的属性值,例如:.findAll(‘span’,{‘class’:{‘green’,’red’}} #返回红色与绿色的span标签text——用标签的文本内容去匹配,例如:namelist = bsObj.findAll(text = ‘the prince’)print(len(namelist))其他BeautifulSoup对象BeautifulSoup对象标签tag对象NavigableString对象Comment对象导航树1.处理子标签和其他后代标签chil

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档