Python-コンフリクトで大学の順位を取る時小さい問題があります。
8055 ワード
解析器がpython標準ライブラリの時にurlを取る=http://www.zuihaodaxue.cn/zuihaodaxuepaiming2017.html問題がありますが、はいて取ります。http://www.zuihaodaxue.cn/zuihaodaxuepaiming2016.htmlまたは他の年の場合は問題ありません。
Beautiful Soup解析器を交換すれば解決できます。
import requests
from bs4 import BeautifulSoup
allUniv = []
def getHTMLText(url):
try:
r = requests.get(url,timeout=30)
r.raise_for_status()
r.encoding = 'utf-8'
return r.text
except:
return ""
def fillUnivList(soup):
data = soup.find_all('tr')
for tr in data:
ltd = tr.find_all('td')
if len(ltd)==0:
continue
singleUniv = []
for td in ltd:
singleUniv.append(td.string)
allUniv.append(singleUniv)
def printUnivList(num):
print("{:^4}{:^10}{:^5}{:^8}{:^10}".format(" "," "," "," "," "))
for i in range(num):
u = allUniv[i]
print("{:^4}{:^10}{:^5}{:^8}{:^10}".format(u[0],u[1],u[2],u[3],u[6]))
def main(num):
url = "http://www.zuihaodaxue.cn/zuihaodaxuepaiming2017.html"
html = getHTMLText(url)
soup = BeautifulSoup(html,features="lxml")# soup = BeautifulSoup(html,"html.parser")
fillUnivList(soup)
# print(allUniv)#######
printUnivList(num)
main(10)
Beautiful Soup解析器を交換すれば解決できます。