600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > python数据分析与挖掘——航空数据模型

python数据分析与挖掘——航空数据模型

时间:2018-07-27 19:47:12

相关推荐

python数据分析与挖掘——航空数据模型

航空数据模型

数据探索

# 导入需要的库import numpy as npimport pandas as pdimport matplotlib.pylab as pltplt.rcParams['font.sans-serif']=['SimHei'] plt.rcParams['axes.unicode_minus']=False plane=pd.read_excel('./航空数据.xls') #读取数据plane.head()

plane.info()des=plane.describe()des

#空值len(plane)-des.loc['count'] plane[plane.isnull().values==True]plane.columns=plane.columns.map(lambda x:x.upper()) # 全部变成大写字母

数据预处理

数据清洗

# 去除票价为空的记录airline_notnull = plane.loc[plane['SUM_YR_1'].notnull() & plane['SUM_YR_2'].notnull(),:]print('删除缺失记录后数据的形状为:',airline_notnull.shape) #结果:删除缺失记录后数据的形状为: (62299, 44)# 只保留票价非零的,或者平均折扣率不为0且总飞行公里数大于0的记录。# 总里程数和折扣率同时为0 的数据,是新客户index1 = airline_notnull['SUM_YR_1'] != 0index2 = airline_notnull['SUM_YR_2'] != 0index3 = (airline_notnull['SEG_KM_SUM']> 0) & (airline_notnull["AVG_DISCOUNT"] != 0)index4 = airline_notnull['AGE'] > 100 # 去除年龄大于100的记录plane = airline_notnull[(index1 | index2) & index3 & ~index4]print('数据清洗后数据的形状为:',plane.shape) #结果:数据清洗后数据的形状为: (62043, 44)

数据规约

plane_1=plane.loc[:,["FFP_DATE", "LOAD_TIME", "LAST_TO_END","FLIGHT_COUNT", "SEG_KM_SUM","AVG_DISCOUNT"]]plane_1.head()plane_1.describe()

构造属性

res=plane_1['LOAD_TIME']-plane_1['FFP_DATE']plane_1['L'] = res.map(lambda x: x / np.timedelta64(30 * 24 * 60, 'm'))plane_1.head()plane_1['R']=plane['LAST_TO_END']plane_1['F']=plane['FLIGHT_COUNT']plane_1['M']=plane['SEG_KM_SUM']plane_1['C']=plane["AVG_DISCOUNT"]plane_2= plane_1[['L', 'R', 'F', 'M', 'C']]plane_2.head() # 合并属性

数据标准化

from sklearn.preprocessing import StandardScalerfrom sklearn.cluster import KMeans # 导入kmeans算法plane=StandardScaler().fit_transform(plane_2)plane[:5,:] #标准化后LRFMC五个属性

建模

k=5 # 确定聚类中心数kmeans_model=KMeans(n_clusters=k,n_jobs=4) # 构建模型fit_kmeans=kmeans_model.fit(plane) #模拟训练cen=kmeans_model.cluster_centers_ # 聚类中心cen

y_pre=kmeans_model.labels_ # 样本的类别标签y_pre # array([3, 3, 3, ..., 1, 2, 2])r1=pd.Series(kmeans_model.labels_).value_counts() # 统计不同类别样本的数目r1 #最终每个类别的数目

输出聚类分群的结果

cluster_center=pd.DataFrame(kmeans_model.cluster_centers_ ,columns=['ZL','ZR','ZF','ZM','ZC']) # 将聚类中心放在数据框中cluster_center.index=pd.DataFrame(kmeans_model.labels_).drop_duplicates().iloc[:,0] # 将样本类别作为数据框索引cluster_center

客户价值分析

labels = ['ZL','ZR','ZF','ZM','ZC']legen = ['客户群' + str(i + 1) for i in cluster_center.index] # 客户群命名,作为雷达图的图例lstype = ['-','--',(0, (3, 5, 1, 5, 1, 5)),':','-.']kinds = list(cluster_center.iloc[:, 0])# 由于雷达图要保证数据闭合,因此再添加L列,并转换为 np.ndarraycluster_center=pd.concat([cluster_center,cluster_center[['ZL']]],axis=1)centers=np.array(cluster_center.iloc[:,0:])# 分割圆周长,并让其闭合n = len(labels)angles = np.linspace(0,2*np.pi,6,endpoint =True)angles #array([0. , 1.25663706, 2.51327412, 3.76991118, 5.02654825,6.28318531])# 绘图ax = plt.subplot(111,polar = True) # 以极坐标的形式绘制图形style=['ro--','bo--','yo--','go--','ko--']c = ['class1','class2','class3','class4','class5']# 画线for i in range(5): #for i in range(len(kinds)):ax.plot(angles, centers[i],style[i],label = c[i])# 添加属性标签ax.set_thetagrids(angles * 180/np.pi, ['ZL','ZR','ZF','ZM','ZC'])plt.legend(loc='lower right', bbox_to_anchor=(1.5, 0.0))

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。