使用Python爬取最好大学网大学排名
本文实例为大家分享了Python爬取最好大学网大学排名的具体代码,供大家参考,具体内容如下
源代码:
#-*-coding:utf-8-*-
'''''
Createdon2017年3月17日
@author:lavi
'''
importrequests
frombs4importBeautifulSoup
importbs4
defgetHTMLText(url):
try:
r=requests.get(url)
r.raise_for_status
r.encoding=r.apparent_encoding
returnr.text
except:
return""
deffillUnivList(univList,html):
soup=BeautifulSoup(html,"html.parser")
fortrinsoup.find("tbody").children:
ifisinstance(tr,bs4.element.Tag):#tobody有的节点是空串,属于要判断类型进行过滤
tds=tr("td")#等价于tr.find_all("td")
univList.append([tds[0].string,tds[1].string,tds[2].string])#NavigableString可以跨越多个层次
defprintUnivList(univList,num):
tplt="{0:^6}\t{1:^10}\t{2:^6}"#:前的数字说明使用format函数的第几个参数填充模板
print(tplt.format("排名","学校名称","总分",chr(12288)))
foriinrange(num):
u=univList[i]
print(tplt.format(u[0],u[1],u[2],chr(12288)))
defmain():
url="http://www.zuihaodaxue.cn/zuihaodaxuepaiming2016.html";
html=getHTMLText(url)
univList=[]
fillUnivList(univList,html)
printUnivList(univList,20)
main()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。