用python爬取中國大學(xué)排名網(wǎng)站排名信息
程序解決問題如下:
利用python網(wǎng)絡(luò)爬蟲爬取中國大學(xué)排名網(wǎng)站上的排名信息,將排名前20的大學(xué)的信息保存為文本文件,并在窗口打印出這20所大學(xué)的信息,按列打印和保存。
程序代碼如下:
import requests
from bs4 import BeautifulSoup
import bs4
def getHTMLText(url):
try:
r = requests.get(url, timeout=30)
r.raise_for_status()
r.encoding = r.apparent_encoding
return r.text
except:
return ""
def fillUnivList(ulist, html):
soup = BeautifulSoup(html, "html.parser")
for tr in soup.find('tbody').children:
if isinstance(tr, bs4.element.Tag):
tds = tr('td')
hdfd = tds[0].find('div')
tt = hdfd.string.split()
ff = "".join(tt)
attr = tds[1].find('a')
hh = tds[4].string.split()
hg = "".join(hh)
shf=tds[2].text.split()
shfn="".join(shf)
ulist.append([ff, attr.string,shfn,hg])
def printUnivList(ulist, num):
tplt = "{0:^10}\t{1:{4}^10}\t{2:^10}\t{3:^10}"
print(tplt.format("排名","學(xué)校名稱","省份","總分", chr(12288)))
with open('save.txt', 'w+', encoding='utf-8') as f:
f.write(tplt.format("排名","學(xué)校名稱","省份","總分", chr(12288)))
f.write('\n')
for i in range(num):
u = ulist[i]
print(tplt.format(u[0], u[1], u[2],u[3],chr(12288)))
with open('save.txt', 'a', encoding='utf-8') as f:
f.write(tplt.format(u[0], u[1], u[2],u[3],chr(12288)))
f.write('\n')
def main():
with open('save.txt', 'w+', encoding='utf-8') as f:
f.write("排名,學(xué)校,省份,總分\n")
f.close()
uinfo = []
url = 'https://www.shanghairanking.cn/rankings/bcur/2021'
html = getHTMLText(url)
fillUnivList(uinfo, html)
printUnivList(uinfo, 20)
main()程序運(yùn)行結(jié)果如下:


到此這篇關(guān)于用python爬取中國大學(xué)排名網(wǎng)站排名信息的文章就介紹到這了,更多相關(guān)python爬取中國大學(xué)排名信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Pytorch的MNIST數(shù)據(jù)集的預(yù)處理詳解
今天小編就為大家分享一篇關(guān)于Pytorch的MNIST數(shù)據(jù)集的預(yù)處理詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01
在Python中實(shí)現(xiàn)函數(shù)重載的示例代碼
這篇文章主要介紹了在Python中實(shí)現(xiàn)函數(shù)重載的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Python數(shù)據(jù)分析之?Pandas?Dataframe修改和刪除及查詢操作

