大学排名

Posted 飞起的小田

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了大学排名相关的知识,希望对你有一定的参考价值。

Python爬虫程序获取源码中的内容

requests库用来获取源码:

  requests.get(url)返回URL页面的源码

  requests.raise_for_status()检测链接是否建立成功,只有返回200是成功,其余都会抛出错误给except

  requests.encoding = requests.apparent_encoding用来改变编码方式

BeautifulSoup用来处理html源码:

  北京理工大学的嵩天老师在中国大学MOOC上的课程说的很好

  http://www.icourse163.org/learn/BIT-1001870001?tid=1001962001#/learn/content?type=detail&id=1002702161&cid=1003064638

 

这个程序里有很强的格式化输出.format()和补齐中文空格的 char(12288)

import requests
import bs4
from bs4 import BeautifulSoup

def Gethtml(url):
  try:
    r = requests.get(url,timeout=30)
    r.raise_for_status()
    r.encoding = r.apparent_encoding
    return r.text
  except:
    return ""

def BaocunList(ulist,html):
  soup = BeautifulSoup(html, "html.parser")
  for tr in soup.find(‘tbody‘).children:
    if isinstance(tr, bs4.element.Tag):#用来检测tr是不是标签类型,是则进
      tds = tr(‘td‘)
      ulist.append([tds[0].string, tds[1].string, tds[2].string, tds[3].string ,tds[4].string])

def PrintList(ulist, num):
  tplt = "{0:^10}\t{1:{5}^10}\t{2:^10}\t{3:^10}\t{4:^10}"
  print(tplt.format("排名","学校名称","省市","总分","生源质量(高考成绩)",chr(12288)))
  for i in range(num):
    u=ulist[i]
    print(tplt.format(u[0],u[1],u[2],u[3],u[4],chr(12288)))

def main():
  url = ‘http://zuihaodaxue.cn/zuihaodaxuepaiming2016.html‘
  r = Gethtml(url)
  List = []
  BaocunList(List,r)
  PrintList(List,50)

main()

以上是关于大学排名的主要内容,如果未能解决你的问题,请参考以下文章

中国大学排名(定向爬虫)实例

国内,美国数学专业排名

爬虫 中国大学排名

爬取:中国大学排名

2019年全国前50大学+武汉大学2015—2019年的全国排名

2019年全国前50大学+武汉大学2015—2019年的全国排名