日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Python爬取歷年高考分?jǐn)?shù)線,幫你預(yù)測2018年高考分?jǐn)?shù)線

粉絲獨(dú)白

創(chuàng)新互聯(lián)長期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為汪清企業(yè)提供專業(yè)的網(wǎng)站制作、做網(wǎng)站汪清網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

高考已經(jīng)結(jié)束了,相信絕大部分同學(xué)都在放松自己了,畢竟壓抑了這么久?,F(xiàn)在雖然距離高考放榜還有一段時(shí)間,可能有一些同學(xué)已經(jīng)迫不及待地想知道自己考的怎樣。因此,現(xiàn)在就來爬取高考網(wǎng)上的近幾年高考分?jǐn)?shù)線,看一下近幾年分?jǐn)?shù)線的變化趨勢,從而心里面有個(gè)底,這樣才能夠更加放松的去嗨皮。

使用的工具庫

  • beautifulsoup
  • mongodb
  • echarts

1.總體思路

高考網(wǎng)上,可以查看各省的分?jǐn)?shù)線,其中文理科都有2009-2017年的數(shù)據(jù),所以可以直接爬取這些數(shù)據(jù)下來存到MongoDB中,然后再使用echarts進(jìn)行繪圖展示,從而可以更加直觀的看到高考分?jǐn)?shù)線的變化趨勢。

2.爬取數(shù)據(jù)

(1)獲取各省的分?jǐn)?shù)線信息

有兩種方法可以達(dá)到這個(gè)目的

1).通過拼接URL鏈接切換省份,可以得出鏈接的變化規(guī)律:只要替換省份的拼音上去就可以請求到:

http://www.gaokao.com/guangdong/fsx/

http://www.gaokao.com/shanghai/fsx/

推薦使用pypinyin模塊——漢字拼音轉(zhuǎn)換模塊/工具。直接使用lazy_pinyin方法就可以得到各省的拼音。由于返回的是列表,所以還需要處理一下才能使用。

 
 
 
 
  1. >>> from pypinyin import lazy_pinyin  
  2. >>> lazy_pinyin('北京')  
  3. ['bei', 'jing'] 

2).通過獲取地區(qū)導(dǎo)航中的各省鏈接,直接得到URL:

獲取各省份的鏈接:

 
 
 
 
  1. # 獲取省份及鏈接  
  2. pro_link = []  
  3. def get_provice(url):  
  4.    web_data = requests.get(url, headers=header)  
  5.    soup = BeautifulSoup(web_data.content, 'lxml')  
  6.    provice_link = soup.select('.area_box > a')  
  7.    for link in provice_link:  
  8.        href = link['href']  
  9.        provice = link.select('span')[0].text  
  10.        data = {  
  11.            'href': href,  
  12.            'provice': provice  
  13.        }  
  14.        provice_href.insert_one(data)#存入數(shù)據(jù)庫  
  15.        pro_link.append(href) 

(2)爬取分?jǐn)?shù)線

接下來就可以開始爬取分?jǐn)?shù)線了,通過審查元素(如下圖),直接使用beautifulsoup來過濾內(nèi)容。

 
 
 
 
  1. # 獲取分?jǐn)?shù)線  
  2. def get_score(url):  
  3.    web_data = requests.get(url, headers=header)  
  4.    soup = BeautifulSoup(web_data.content, 'lxml')  
  5.    # 獲取省份信息  
  6.    provice = soup.select('.col-nav span')[0].text[0:-5]  
  7.    # 獲取文理科  
  8.    categories = soup.select('h3.ft14')  
  9.    category_list = []  
  10.    for item in categories:  
  11.        category_list.append(item.text.strip().replace(' ', ''))#替換空格  
  12.    # 獲取分?jǐn)?shù)  
  13.    tables = soup.select('h3 ~ table')  
  14.    for index, table in enumerate(tables):  
  15.        tr = table.find_all('tr', attrs={'class': re.compile('^c_\S*')})#使用正則匹配  
  16.        for j in tr:  
  17.            td = j.select('td')  
  18.            score_list = []  
  19.            for k in td:  
  20.                # 獲取每年的分?jǐn)?shù)  
  21.                if 'class' not in k.attrs:  
  22.                    score = k.text.strip()  
  23.                    score_list.append(score)  
  24.  
  25.                # 獲取分?jǐn)?shù)線類別  
  26.                elif 'class' in k.attrs:  
  27.                    score_line = k.text.strip()  
  28.  
  29.                score_data = {  
  30.                    'provice': provice.strip(),#省份  
  31.                    'category': category_list[index],#文理科分類  
  32.                    'score_line': score_line,#分?jǐn)?shù)線類別  
  33.                    'score_list': score_list#分?jǐn)?shù)列表  
  34.                }  
  35.            score_detail.insert_one(score_data)#插入數(shù)據(jù)庫  

3.開始爬取

由于有30多個(gè)省份,所以這里使用多線程來爬取,可以提高爬取效率。

 
 
 
 
  1. if __name__ == '__main__':  
  2.  
  3.    header = {  
  4.        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:58.0) Gecko/20100101 Firefox/58.0',  
  5.        'Connection': 'keep - alive'  
  6.        }  
  7.    url = 'http://www.gaokao.com/guangdong/fsx/'  
  8.  
  9.    get_provice(url)  
  10.    pool = Pool()  
  11.    pool.map(get_score, [i for i in pro_link])#使用多線程  

使用多線程爬取的話,不用1分鐘就可以爬完所有的數(shù)據(jù)了???,多線程可牛逼了,叉會腰先。

4.數(shù)據(jù)可視化

爬取數(shù)據(jù)只是***步,接下來就要對數(shù)據(jù)進(jìn)行處理展示了。從mongodb 中查找出數(shù)據(jù),對數(shù)據(jù)進(jìn)行清洗整理,由于我這里的pyecharts有點(diǎn)問題,所以使用echarts進(jìn)行展示。

1).篩選省份等信息

直接通過mongodb的find函數(shù),限制查找的內(nèi)容。

 
 
 
 
  1. import pymongo  
  2. import charts  
  3. client = pymongo.MongoClient('localhost', 27017)  
  4. gaokao = client['gaokao']  
  5. score_detail = gaokao['score_detail']  
  6.  
  7. # 篩選分?jǐn)?shù)線、省份、文理科  
  8. def get_score(line,pro,cate):  
  9.    score_list=[]  
  10.    for i in score_detail.find({"$and":[{"score_line":line},{"provice":pro},{'category': cate}]}):  
  11.        score_list = i['score_list']  
  12.        score_list.remove('-')#去掉沒有數(shù)據(jù)的欄目  
  13.        score_list = list(map(int, score_list))  
  14.        score_list.reverse()  
  15.        return score_list 

2).定義相關(guān)數(shù)據(jù)

 
 
 
 
  1. # 獲取文理科分?jǐn)?shù)  
  2. line = '一本'  
  3. pro = '北京'  
  4. cate_wen = '文科'  
  5. cate_li = '理科'  
  6. wen=[]  
  7. li = []  
  8. wen=get_score(line,pro,cate_wen)#文科  
  9. li=get_score(line,pro,cate_li)#理科 
  10.  
  11.  
  12. # 定義年份  
  13. year = [2017,2016,2015,2014,2013,2012,2011,2010,2009]  
  14. year.reverse()  

3).折線圖展示

 
 
 
 
  1. series = [  
  2.    {  
  3.    'name': '文 科', 
  4.    'data': wen,  
  5.    'type': 'line'  
  6. }, {  
  7.    'name': '理科',  
  8.    'data': li,  
  9.    'type': 'line',  
  10.    'color':'#ff0066'  
  11. }  
  12.         ]  
  13. options = {  
  14.    'chart'   : {'zoomType':'xy'},  
  15.    'title'   : {'text': '{}省{}分?jǐn)?shù)線'.format(pro,line)},  
  16.    'subtitle': {'text': 'Source: gaokao.com'},  
  17.    'xAxis'   : {'categories': year},  
  18.    'yAxis'   : {'title': {'text': 'score'}}  
  19.    }  
  20.  
  21. charts.plot(series, options=options,show='inline')  

這樣就可以得到下面的歷年分?jǐn)?shù)線趨勢圖了。當(dāng)然,可以修改get_score的參數(shù)就可以的到其他省份的信息了。

5.預(yù)測分?jǐn)?shù)線

通過折線圖,可以大概的預(yù)測2018年北京高考一本的分?jǐn)?shù)線:文科在550-560分之間;理科在530-540分之間。當(dāng)然,這只是預(yù)測的,如果有特殊情況的話,可能波動會比較大。另外,還可以通過拉格朗日插值法求出今年的分?jǐn)?shù)線,這樣比較準(zhǔn)確,但是由于過程比較麻煩,所以這里只是目測而已。


網(wǎng)站欄目:Python爬取歷年高考分?jǐn)?shù)線,幫你預(yù)測2018年高考分?jǐn)?shù)線
網(wǎng)站路徑:http://www.5511xx.com/article/ccehjig.html