前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >敲代码前先构思一下-Graphviz-01

敲代码前先构思一下-Graphviz-01

作者头像
zishendianxia
发布2019-10-23 17:11:38
9350
发布2019-10-23 17:11:38
举报
文章被收录于专栏:Python工程师Python工程师

系统:Windows 7 语言版本:Anaconda3-4.3.0.1-Windows-x86_64 编辑器:pycharm-community-2016.3.2

  • 在写代码前,我相信大家都会先思考一下架构,然后可能是边写边想
  • 这样的缺陷是:某些问题太复杂,想点写点,后期返工或者推倒重来可能性很大
  • 对于个人完成的小项目,个人建议先把逻辑画出来,一个逻辑流程图
  • 相信流程图,常规想到就是微软的VISIO,今天我们介绍个不一样的,Graphviz

Part 1:VISIO对比Graphviz

  1. VISIO基本是手工画,理论上你连蒙娜丽莎都可以画出来,非常耗时,尤其中间有改动,整个图可能都要改动
  2. 因为我们目标更多的是逻辑性,其实对美观要求没那么高,但是要很方便,迭代快,要不等你画好图,
  3. Graphviz其实是对dot语言的渲染,dot语言非常易学,如果要修改图,修改一下代码就可以,重新生成图片就ok

综述:Graphviz非常高效,所想即所得

官网:http://www.graphviz.org/

使用graphviz画图示例1(官网)

使用graphviz画图示例2(官网)

使用graphviz画图示例2-dot代码(官网)

代码语言:javascript
复制
graph G {
 e
 subgraph clusterA {
   a -- b;
   subgraph clusterC {
     C -- D;
   }
 }
 subgraph clusterB {
   d -- f
 }
 d -- D
 e -- clusterB
 clusterC -- clusterB
}

代码截图

Part 2:dot语法

  1. dot有三大对象:线
  2. 对应以上代码,我们来解读一下
    • 首先是以大括号来表示{}一个封闭的关系
    • 第1行:首先定义了一个为G的图(graph)
    • 第2行:节点e(可以先定义,也可以不定义直接使用)
    • 第3行:子图(subgraph),名称为clusterA,子图中所有对象会用一个框进行封闭
    • 第4行:节点a,节点b,并且两者相连接(a — b)
    • 第5行:子图(subgraph),名称为clusterC,相当于子图中的子图
    • 第14行:子图指向子图(clusterC — clusterB)

以上为本次的学习内容,下回见

本文为原创作品,如若转载请标明出处,如发现有错误,欢迎留言指出


本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-09-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python工程师 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Part 1:VISIO对比Graphviz
  • Part 2:dot语法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档