5-2 决策树算法预测销量高低代码

本文介绍了一种利用决策树算法预测销售业绩的方法。通过对天气、是否为周末及是否有促销活动等因素进行编码,并使用决策树分类器进行训练,最终生成了用于预测销量高低的决策树模型。
#-*- coding: utf-8 -*-
import pandas as pd

inputfile = '../data/sales_data.xls'
data = pd.read_excel(inputfile, index_col = u'序号')

data[data == u'好'] = 1
data[data == u'是'] = 1
data[data == u'高'] = 1
data[data != 1] = -1
print(data)
print("-------------------------------------")
x = data.iloc[:,:3].as_matrix().astype(int)
y = data.iloc[:,3].as_matrix().astype(int)
print("x=",x)
print("y=",y)


from sklearn.tree import DecisionTreeClassifier as DTC
dtc = DTC(criterion='entropy')#熵
dtc.fit(x, y)#训练模型


from sklearn.tree import export_graphviz
x = pd.DataFrame(x)
from sklearn.externals.six import StringIO
x = pd.DataFrame(x)
with open("tree.dot", 'w') as f:
  f = export_graphviz(dtc, feature_names = x.columns, out_file = f)
print("OK")


使用的数据集为:


序号天气是否周末是否有促销销量
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
x = data.iloc[:,:3].as_matrix().astype(int)#指的是取第1行下面和第1列右侧3列数据
y = data.iloc[:,3].as_matrix().astype(int)#指的是取第4列数据



                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值