上次已經講了怎麼下載數據,此次就不說廢話了,直接開始。首先導入相應的模塊,而後檢視一下數據狀況。對數據有一個大體的瞭解以後,開始進行下一步操做。git
train_data['Survived'].value_counts()
train_data.groupby('Pclass')['Survived'].mean()
train_data.groupby('Embarked')['Survived'].value_counts() sns.countplot('Embarked',hue='Survived',data=train_data)
先將 label 提取出來,而後將 train 和 test 合併起來一塊兒處理。github
y_train = train_data.pop('Survived').astype(str).values data = pd.concat((train_data, test_data), axis=0)
(1)SibSp/Parch (兄弟姐妹配偶數 / 父母孩子數)app
因爲這兩個屬性都和 Survived 沒有很大的影響,將這兩個屬性的值相加,表示爲家眷個數。dom
data['FamilyNum'] = data['SibSp'] + data['Parch']
(2)Fare (費用)測試
它有一個缺失值,須要將其補充。(這裏是參考別人的,大神總能發現一些潛在的信息:票價和 Pclass 和 Embarked 有關) 所以,先看一下他們之間的關係以及缺失值的狀況。spa
train_data.groupby(by=["Pclass","Embarked"]).Fare.mean()
缺失值 Pclass = 3, Embarked = S,所以咱們將其置爲14.644083.3d
data["Fare"].fillna(14.644083,inplace=True)
還有 Age 的缺失值也須要處理,我是直接將其設置爲平均值。rest
(1)對 Cabin 進行處理code
Cabin雖然有不少空值,但他的值的開頭都是字母,按我本身的理解應該是對應船艙的位置,因此取首字母。考慮到船艙位置對救生是有必定影響的,雖然有不少缺失值,但仍是把它保留下來,並且因爲 T 開頭的只有一條數據,所以將它設置成數量較小的 G。blog
data['Cabin'] = data['Cabin'].str[0] data['Cabin'][data['Cabin']=='T'] = 'G'
(2)對 Ticket 進行處理
將 Ticket 的頭部取出來當成新列。
data['Ticket_Letter'] = data['Ticket'].str.split().str[0] data['Ticket_Letter'] = data['Ticket_Letter'].apply(lambda x:np.nan if x.isnumeric() else x) data.drop('Ticket',inplace=True,axis=1)
(3)對 Name 進行處理
名字這個東西,雖然它裏面的稱呼可能包含了一些身份信息,但我仍是打算把這一列給刪掉...
data.drop('Name',inplace=True,axis=1)
(4)統一將 categorical 數據進行 One-Hot
One-Hot 大體的意思在以前的文章講過了,這裏也再也不贅述。
data['Pclass'] = data['Pclass'].astype(str) data['FamilyNum'] = data['FamilyNum'].astype(str) dummied_data = pd.get_dummies(data)
(5)數據處理完畢,將訓練集和測試集分開
X_train = dummied_data.loc[train_data.index].values
X_test = dummied_data.loc[test_data.index].values
這裏用到了 sklearn.model_selection 的 GridSearchCV,我主要用它來調參以及評定 score。
xgbc = XGBClassifier() params = {'n_estimators': [100,110,120,130,140], 'max_depth':[5,6,7,8,9]} clf = GridSearchCV(xgbc, params, cv=5, n_jobs=-1) clf.fit(X_train, y_train) print(clf.best_params_) print(clf.best_score_)
{'max_depth': 6, 'n_estimators': 130}
0.835016835016835
rf = RandomForestClassifier() params = { 'n_estimators': [100,110,120,130,140,150], 'max_depth': [5,6,7,8,9,10], } clf = GridSearchCV(rf, params, cv=5, n_jobs=-1) clf.fit(X_train, y_train) print(clf.best_params_) print(clf.best_score_)
{'max_depth': 8, 'n_estimators': 110}
0.8294051627384961
from sklearn.ensemble import VotingClassifier xgbc = XGBClassifier(n_estimators=130, max_depth=6) rf = RandomForestClassifier(n_estimators=110, max_depth=8) vc = VotingClassifier(estimators=[('rf', rf),('xgb',xgbc)], voting='hard') vc.fit(X_train, y_train)
準備就緒,預測並保存模型與結果
y_test = vc.predict(X_test) # 保存模型 from sklearn.externals import joblib joblib.dump(vc, 'vc.pkl') submit = pd.DataFrame(data= {'PassengerId' : test_data.index, 'Survived': y_test}) submit.to_csv('./input/submit.csv', index=False)
最後提交便可,提交的方式也在上一篇提到過了。Over~ 項目地址:Titanic
想要第一時間獲取更多有意思的推文,可關注公衆號: Max的平常操做