• 爬取中国大学排行榜


    功能实现

    1.输入:大学排名url链接

    2.输出:大学排行信息

    所用到的库:BeaitifulSoup,requests

    程序结构设计
    步骤一:利用requests获取网页内容
    步骤二:利用bs4提取网页内容信息到合适的数据结构
    步骤三:在屏幕上打印出来

    建立三个函数,将其分为三个模块。这样能够使代码更加清晰易读,维护方便。
    函数一:getHTMLText()- 获取网页内容
    函数二:fillUnivList()-获取网页大学信息到合适的数据结构
    函数三:printUnivList()-利用数据结构打印到屏幕上

    下面是模板:

    import requests
    from bs4 import BeautifulSoup
    
    def getHTMLText(url):    #获取网页内容
        return""
    
    def fillUnivList(ulist,html):   #提取信息,ulist列表用于储存学校信息,html为getHTMLText返回值
        pass
    
    def printUnivList(ulist,num):    #打印,num为要打印多少学校
        print()
    
    def main():
        url="http://www.zuihaodaxue.com/zuihaodaxuepaiming2018.html"
        html=getHTMLText(url)
        ulist=[]
        fillUnivList(ulist,html)
        printUnivList(ulist,30) # 打印30所学校排名
    
    main()

    接下里就可以按照模板写入相应的代码

    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):   #提取信息,ulist列表用于储存学校信息,html为getHTMLText返回值
        soup=BeautifulSoup(html,"html.parser")  #将getHTMLText获取的内容放到一锅汤里
        for tr in soup.find('tbody').children:
            if isinstance(tr,bs4.element.Tag):
                tds=tr('td')
                ulist.append([tds[0].string,tds[1].string,tds[3].string])
    
    def printUnivList(ulist,num):    #打印,num为要打印多少学校
        print("{:^10}	{:^6}	{:^10}".format("排名","学校名称","总分"))
        for i in range(num):
            u=ulist[i]
            print("{:^10}	{:^6}	{:^10}".format(u[0],u[1],u[2]))
    
    
    def main():
        url="http://www.zuihaodaxue.com/zuihaodaxuepaiming2018.html"
        html=getHTMLText(url)
        ulist=[]
        fillUnivList(ulist,html)
        printUnivList(ulist,30) # 打印30所学校排名
    
    main()

    运行截图

     代码缺陷

    得到的结果排版不工整,于是修改函数printUnivList(ulist,num),代码如下

    def printUnivList(ulist, num):
        tplt = "{0:^10}	{1:{3}^10}	{2:^10}"
        print(tplt.format("排名","学校名称","总分",chr(12288)))
        for i in range(num):
            u=ulist[i]
            print(tplt.format(u[0],u[1],u[2],chr(12288)))

    运行截图

     这样就好看很多啦

     

  • 相关阅读:
    Python对象
    python 迭代器和生成器
    python中logging日志模块详解
    学习中遇到的一些问题(杂谈)
    如何在github上搜索项目
    python闭包与装饰器
    python面试题
    selenium
    python导入自定义包
    About Me、
  • 原文地址:https://www.cnblogs.com/wt714/p/11917769.html
Copyright © 2020-2023  润新知