【Graphviz绘制决策树】基于Graphviz绘制由字典形式表示的决策树图像

Step 1: 下载Graphviz安装包与Graphviz的安装

戳一戳👉进入Graphviz下载官网

(1)进入网站之后根据自身计算机的系统下载相应的安装包

在这里插入图片描述

(2)下载之后将会得到一个如下图所示的文件

在这里插入图片描述

(3)双击此文件进行安装

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
此处注意选择第2项或第3项,这样会自动添加系统的环境变量
当然,如果一不小心选错了,可以选择回退进行更改,也可以找到Graphviz的安装的位置,手动添加系统环境变量(随后将会讲述手动添加环境变量的具体步骤)
在这里插入图片描述
文件并不是很大,简单起见,我就直接使用其提供的默认地址进行安装了。
在这里插入图片描述
在这一步中,我使用的开发平台是Visual Studio Code,所以我就选择了这个文件夹,不过好像没啥影响,就是创建一个快捷方式而已,不影响使用。也可以选择不创建快捷方式。点击安装等待几秒就安装成功了。

补充:手动添加系统变量的步骤
(1)复制graphviz的安装地址(请结合下图安装时所选择的地址找安装位置):

在这里插入图片描述
在这里插入图片描述

(2)使用快捷键Win+Q,并键入环境变量关键字并打开

在这里插入图片描述

(3)添加系统环境变量

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
接着一路点击确定知道窗口关闭即可。

Step 2: 下载在python中的Graphviz这个包

打开vscode,在终端中使用命令:pip install graphviz
在这里插入图片描述

Step 3: 套入模板进行测试

模板来源csdn用户num270710
稍微改动之后,解决了中文乱码的问题
![在这里插入图片描述](https://img-blog.csdnimg.cn/b2832ad058d649f19a2ce61540d72f93.png
改动部分是将每一个node和edge中加入参数fontname来展示中文。

(1)我的用字典表示的树

在这里插入图片描述

(2)测试结果展示

在这里插入图片描述

(3)测试模板源代码
from graphviz import Digraph

# 获取所有节点中最多子节点的叶节点


def getMaxLeafs(myTree):
    numLeaf = len(myTree.keys())
    for key, value in myTree.items():
        if isinstance(value, dict):
            sum_numLeaf = getMaxLeafs(value)
            if sum_numLeaf > numLeaf:
                numLeaf = sum_numLeaf
    return numLeaf


def plot_model(tree, name):
    g = Digraph("G", filename=name, format='png',
                strict=False, encoding='utf-8')
    first_label = list(tree.keys())[0]
    g.node("0", first_label, fontname='Fangsong')
    _sub_plot(g, tree, "0")
    leafs = str(getMaxLeafs(tree) // 10)
    g.attr(rankdir='LR', ranksep=leafs)
    g.view()


root = "0"


def _sub_plot(g, tree, inc):
    global root
    first_label = list(tree.keys())[0]
    ts = tree[first_label]
    for i in ts.keys():
        if isinstance(tree[first_label][i], dict):
            root = str(int(root) + 1)
            g.node(root, list(tree[first_label][i].keys())[
                   0], fontname='Fangsong')
            # 设置fontname来解决中文乱码问题
            g.edge(inc, root, str(i), fontname='Fangsong')
            _sub_plot(g, tree[first_label][i], root)
        else:
            root = str(int(root) + 1)
            g.node(root, tree[first_label][i], fontname='Fangsong')
            g.edge(inc, root, str(i), fontname='Fangsong')


my_tree = {'天气': {'雨': {'风': {'有风': 'N', '无风': 'P'}},
                  '晴': {'湿度': {'高': 'N', '正常': 'P'}}, '多云': 'P'}}
print('my_tree: ', my_tree)
plot_model(my_tree, "tree.gv")
  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值