【Graphviz】数据网络的布局软件

news/2025/2/11 19:52:26/

一、认识graphviz

接触graphviz是几年前的一个项目,要画出数据网络的布局,使用graphviz能比较清楚的画出数据之间的关系。
可以在gallery中查看他能完成的图形:http://www.graphviz.org/gallery/。graphviz最方便的地方在于能够很快的清晰的画出点与点之间的关系,并且有许多布局算法能够很好的去布局。
之前使用它画过流程图,如:

image.png

 

还有决策树。使用twopi画出数据的关联关系:

 

image.png

二、安装graphviz

官网下载:http://www.graphviz.org/download/。
根据自己的版本来选择:

image.png

 

安装在任意喜欢的位置。但是需要把安装目录的graphviz/bin加入环境变量PATH里,我这里只写了相对路径。
打开cmd,输入:dot --help,如果弹出以下信息,就是安装成功:

image.png

三、使用graphviz

3.1 基本信息

graphviz中包含了众多的布局器:

dot 默认布局方式,主要用于有向图
neato 基于spring-model(又称force-based)算法
twopi 径向布局
circo 圆环布局
fdp 用于无向图

以上布局我都使用过,但是个人比较倾向dot和twopi,可以根据需求来画图。

3.2 基本使用

以画一个dot布局为例子:
(1)建立一个first.dot脚本:

digraph first2{
a;
b;
c;
d;
a->b;
b->d;
c->d;
}

解释:digraph是画图类型,接触高级使用可以有不同的类型,first2可以和文件名first不一样。画了abcd4个点。然后a->b表示a点指向b点,如果有线条的指向,可以不用先声明点。即,上述代码等价于:

digraph first2{
a->b;
b->d;
c->d;
}

(2)画图
打开cmd到first.dot目录下,运行:
dot -Tpng first.dot -o first.png
可以得到画好的图形。
解释:dot表示使用的是dot布局,其他布局相应的修改即可,-T表示格式,即画成png格式,-o表示重命名为first.png。

在这里如果出现syntax error,可看第四部分常见问题解决。

(3)画图结果
上面的简单的代码得到以下结果:

image.png

3.3 高级使用

网上参考一篇博客,写的比较详细,对于很多应用场景都有提到: http://icodeit.org/2012/01/%E4%BD%BF%E7%94%A8graphviz%E7%BB%98%E5%88%B6%E6%B5%81%E7%A8%8B%E5%9B%BE/

但是,想要查询每个属性的信息,可以看官网的查询文档:
Node, Edge and Graph Attributes(属性):https://graphviz.gitlab.io/_pages/doc/info/attrs.html
Node Shapes(节点形状):https://graphviz.gitlab.io/_pages/doc/info/shapes.html
Arrow Shapes(箭头形状):https://graphviz.gitlab.io/_pages/doc/info/arrows.html

四、常见问题

4.1 编译问题

如果遇见以下错误:

image.png

解决:
1、编码问题。
把文件另存为,'utf-8'或'ANSI'(不涉及中文使用时),看是否编译出问题。
2、对于文件格式的识别。
将文件开头加2个空格,其识别的时候,对于第一个字符,在windows下会问题,源于文件的编码格式。

4.2 中文问题

修改文件,Graphviz2.37\etc\fonts\fonts.conf,安装的相对目录。
(1)文件修改
将下列代码:

<dir>#WINDOWSFONTDIR#</dir>
<dir>~/.fonts</dir>

修改为:

<dir>C:\WINDOWS\Fonts</dir>
<dir>~/.fonts</dir>

(2)文本设置
2.1 文本保存的编码为"utf-8"
2.2 文本中的字体设置
使用的dot文件按照规则属性,设置fontname属性即可:

fontname="Microsoft YaHei"
edge [fontname="Microsoft YaHei"];
node [fontname="Microsoft YaHei"];

以上分别是全局、边、节点的设置。

可用的中文,有很多:

黑体:SimHei 
宋体:SimSun 
新宋体:NSimSun 
仿宋:FangSong 
楷体:KaiTi 
新细明体:PMingLiU
细明体:MingLiU
标楷体:DFKai-SB
微软正黑体:Microsoft JhengHei
微软雅黑体:Microsoft YaHei 

2.3 dot文件中的中文前后加空格
如:label="节点"应为label=" 节点 "


http://www.ppmy.cn/news/558807.html

相关文章

Graphviz使用注意事项

系统环境&#xff1a;win10 64bit 工具&#xff1a;Graphviz, Notepad 关于Graphviz的介绍就不多说了&#xff0c;官网下载安装即可&#xff0c;安装后手动将程序所在文件目录添加到系统环境变量&#xff0c;然后打开控制台窗口才能使用dot,neato等程序。 dot 渲染的图具有明…

graphviz基本使用及常见问题

一、认识graphviz 接触graphviz是几年前的一个项目&#xff0c;要画出数据网络的布局&#xff0c;使用graphviz能比较清楚的画出数据之间的关系。 可以在gallery中查看他能完成的图形&#xff1a;http://www.graphviz.org/gallery/。graphviz最方便的地方在于能够很快的清晰的…

给小白准备的graphviz图文安装教程(2021最新)

WinR→cmd 百度有说命令行中输入conda install python-graphviz这行命令就能直接安装成功。 但是为了稳妥起见我准备按部就班的来。如果想快捷一些的可以直接执行上面那行代码进行安装 &#xff08;可以直接看这篇文章最后一句话的描述来决定&#xff09; 官网&#xff1a;ht…

Windows10(64位)下快速安装 pygraphviz

Windows下并没有安装pygraphviz的快捷方式&#xff0c;使用 conda install -c anaconda pygraphviz 的命令方式只能在linux中。 如果你打开https://anaconda.org/anaconda/pygraphviz/files就发现&#xff0c;这里确实没有windows下可以使用的轮子。 Stackoverflow上的参考 …

graphviz例子

window系统下得到一个目录下所有的文件list.txt&#xff1a; 然后输入&#xff1a;dir/b/on >list.txt 并按下回车键 /b  使用空格式(没有标题信息或摘要)。 /N  按名称(字母顺序) dir/b/n/on >list.txt 获取当前目录及子目录下所有文件名 dir /s/b *.* > l…

开源的图可视化工具——Graphviz

g r a p h v i z graphviz graphviz&#xff08;Graph Visualization Software&#xff09;是一个由 A T & T AT\&T AT&T实验室启动的开源工具包&#xff0c;用于绘制 D O T DOT DOT语言脚本描述的图形。 实现可视化效果&#xff08;官网摘取&#xff09;&#xf…

三维重建-使用开源库openMVG与openMVS

在前面我们已经介绍了编译openMVG与openMVS的方法&#xff0c;得到了openMVG与openMVS的x64位的Debug版本和Release版本 vcpkg问题-环境配置 关于使用vcpkg的一些技巧补充 openMVG编译 openMVS编译 参考博客&#xff1a; https://blog.csdn.net/qq_39615622/article/detai…

在Graphviz中画出好看的二叉树、B树、如何使用pos变量

一、二叉树 (一) 前提 使用过Graphviz画二叉树的同学都会发现&#xff0c;画出来的东西没有像教材那样规规矩矩&#xff0c;对于有强迫症的同学来说&#xff0c;可以采用以下思路进行完善 (二) IDEA Dot startuml digraph btree {graph [nodesep0.1, pad0.02, ranksep0.5]…