Python在日常生活中有很多應(yīng)用場(chǎng)景,今天教大家如何使用Python實(shí)現(xiàn)預(yù)測(cè)NBA比賽結(jié)果,在此提供一些思路希望能對(duì)各位有所幫助。
數(shù)據(jù)選取
獲取數(shù)據(jù)的鏈接為:www.basketball-reference.com
獲取的數(shù)據(jù)內(nèi)容為:
每支隊(duì)伍平均每場(chǎng)比賽的表現(xiàn)統(tǒng)計(jì);
每支隊(duì)伍的對(duì)手平均每場(chǎng)比賽的表現(xiàn)統(tǒng)計(jì);
綜合統(tǒng)計(jì)數(shù)據(jù);
2016-2017年NBA常規(guī)賽以及季后賽的每場(chǎng)比賽的比賽數(shù)據(jù);
2017-2018年NBA的常規(guī)賽以及季后賽的比賽安排。
建模思路
主要利用數(shù)據(jù)內(nèi)容的前四項(xiàng)來(lái)評(píng)估球隊(duì)的戰(zhàn)斗力。
利用數(shù)據(jù)內(nèi)容的第五項(xiàng)也就是比賽安排來(lái)預(yù)測(cè)每場(chǎng)比賽的獲勝隊(duì)伍。
利用方式為:
數(shù)據(jù)內(nèi)容的前三項(xiàng)以及根據(jù)數(shù)據(jù)內(nèi)容的第四項(xiàng)計(jì)算的Elo等級(jí)分作為每支隊(duì)伍的特征向量。
Elo等級(jí)分介紹(相關(guān)文件中有):
為方便起見(jiàn),假設(shè)獲勝方提高的Elo等級(jí)分與失敗方降低的Elo等級(jí)分?jǐn)?shù)值相等。
另外,為了體現(xiàn)主場(chǎng)優(yōu)勢(shì),主場(chǎng)隊(duì)伍的Elo等級(jí)分在原有基礎(chǔ)上增加100。
代碼流程
數(shù)據(jù)初始化;
計(jì)算每支隊(duì)伍的Elo等級(jí)分(初始值1600);
基于數(shù)據(jù)內(nèi)容前三項(xiàng)和Elo等級(jí)分建立2016-2017年常規(guī)賽和季后賽中每場(chǎng)比賽的數(shù)據(jù)集;
使用sklearn中的LogisticRegression函數(shù)建立回歸模型;
利用訓(xùn)練好的模型對(duì)17-18年常規(guī)賽和季后賽的比賽結(jié)果進(jìn)行預(yù)測(cè);
將預(yù)測(cè)結(jié)果保存到17-18Result.CSV文件中。
開(kāi)發(fā)工具
Python版本:3.5.4
相關(guān)模塊:
pandas模塊、numpy模塊、sklearn模塊以及一些Python自帶的模塊。
環(huán)境搭建
安裝Python并添加到環(huán)境變量,pip安裝需要的相關(guān)模塊即可。
使用演示
在cmd窗口運(yùn)行Analysis_NBA_Data.py文件即可:
結(jié)果:
到此這篇關(guān)于利用Python實(shí)現(xiàn)預(yù)測(cè)NBA比賽結(jié)果的文章就介紹到這了。