python利用sklearn包编写决策树源代码

作者:薄樱 时间:2022-01-06 08:14:04 

本文实例为大家分享了python编写决策树源代码,供大家参考,具体内容如下

因为最近实习的需要,所以用python里的sklearn包重新写了一次决策树。

工具:sklearn,将dot文件转化为pdf格式(是为了将形成的决策树可视化)graphviz-2.38,下载解压之后将其中的bin文件的目录添加进环境变量

源代码如下:


from sklearn.feature_extraction import DictVectorizer
import csv
from sklearn import tree
from sklearn import preprocessing
from sklearn.externals.six import StringIO
from xml.sax.handler import feature_external_ges
from numpy.distutils.fcompiler import dummy_fortran_file

# Read in the csv file and put features into list of dict and list of class label
allElectronicsData = open(r'E:/DeepLearning/resources/AllElectronics.csv', 'rt')
reader = csv.reader(allElectronicsData)
headers = next(reader)
featureList = []
lableList = []
for row in reader:
lableList.append(row[len(row)-1])
rowDict = {}
#不包括len(row)-1
for i in range(1,len(row)-1):
rowDict[headers[i]] = row[i]
featureList.append(rowDict)
print(featureList)

vec = DictVectorizer()
dummX = vec.fit_transform(featureList).toarray()
print(str(dummX))
lb = preprocessing.LabelBinarizer()
dummY = lb.fit_transform(lableList)
print(str(dummY))

#entropy=>ID3
clf = tree.DecisionTreeClassifier(criterion='entropy')
clf = clf.fit(dummX, dummY)
print("clf:"+str(clf))

#可视化tree
with open("resultTree.dot",'w')as f:
f = tree.export_graphviz(clf, feature_names=vec.get_feature_names(),out_file = f)

#对于新的数据怎样来查看它的分类
oneRowX = dummX[0,:]
print("oneRowX: "+str(oneRowX))
newRowX = oneRowX
newRowX[0] = 1
newRowX[2] = 0

predictedY = clf.predict(newRowX)
print("predictedY: "+ str(predictedY))

这里的AllElectronics.csv,形式如下图所示:

python利用sklearn包编写决策树源代码

今天早上好不容易将jdk、eclipse以及pydev装进linux,但是,但是,但是,想装numpy的时候,总是报错,发现是没有gcc,然后又去装gcc,真是醉了,到现在gcc还是没有装成功,再想想方法

来源:https://www.cnblogs.com/yunerlalala/p/6240296.html

标签:python,决策树
0
投稿

猜你喜欢

  • YUI Grids CSS 解读

    2008-05-28 12:49:00
  • Python多进程原理与用法分析

    2023-11-30 15:26:11
  • 用Python实现一个简单的线程池

    2023-09-21 15:14:56
  • Golang标准库binary详解

    2024-04-25 13:19:47
  • 获取Django项目的全部url方法详解

    2022-09-08 23:06:27
  • 基于Python3编写一个GUI翻译器

    2022-07-07 07:57:54
  • Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理

    2010-07-16 13:27:00
  • django query模块

    2021-12-01 09:16:22
  • 浅谈Django自定义模板标签template_tags的用处

    2023-03-13 11:21:08
  • 对tf.reduce_sum tensorflow维度上的操作详解

    2023-01-07 14:10:28
  • pytorch使用-tensor的基本操作解读

    2022-05-23 03:15:12
  • python中print()函数的“,”与java中System.out.print()函数中的“+”功能详解

    2021-12-18 10:27:02
  • sql 修改表的所有者

    2024-01-14 15:05:19
  • Python轮播图与导航栏功能的实现流程全讲解

    2021-08-08 22:46:32
  • Python之二维正态分布采样置信椭圆绘制

    2021-04-08 06:39:09
  • VSCode Python开发环境配置的详细步骤

    2021-06-15 23:29:15
  • Sql Server中清空所有数据表中的记录

    2024-01-15 00:10:26
  • python自动登录12306并自动点击验证码完成登录的实现源代码

    2021-07-08 12:50:29
  • Python字符串本身作为bytes进行解码的问题

    2022-12-22 07:18:42
  • 用Javascript正则表达式验证Email地址

    2009-12-09 15:56:00
  • asp之家 网络编程 m.aspxhome.com