python中流程图_python用graphviz画流程图

问题描述

项目中需要用到流程图,如果用js的echarts处理,不同层级建动态计算位置比较复杂,考虑用python来实现

测试demo实现效果如下

841731-20190711152608429-1852392723.png

完整代码

import yaml

import os

import ibm_db

from graphviz import Digraph

from datetime import datetime

# db连接

def db2_query(sql):

conn = ibm_db.connect(

"DATABASE=%s;HOSTNAME=%s;PORT=%s;PROTOCOL=TCPIP;UID=%s;PWD=%s" % (

config['db2_databse'],

config['db2_host'],

config['db2_port'],

config['db2_user'],

config['db2_password']

), "", ""

)

if conn:

# 执行

stmt = ibm_db.exec_immediate(conn, sql)

result = ibm_db.fetch_both(stmt)

return result, stmt, conn

# 添加所有的点

def add_nodes():

sql = "SELECT * FROM AML.DEP_OFTEN_TRAD WHERE ACCOUNT_NO=" + ACCOUNT_NO + " ORDER BY NUM DESC fetch first 10 rows ONLY;"

result, stmt, conn = db2_query(sql)

nodes = []

nodes_dict = {}

nodes_dict[ACCOUNT_NO] = 'A'

count = 0

while (result):

count = count + 1

print(chr(ord('A') + count) + "," + result[3])

dot.node(chr(ord('A') + count), result[3], shape="rectangle", color="orange")

nodes.append(result[2])

nodes_dict[result[2]] = chr(ord('A') + count)

print('-----------------')

result = ibm_db.fetch_both(stmt)

# 关闭数据库连接

ibm_db.close(conn)

nodes.append(ACCOUNT_NO)

return dot, nodes, nodes_dict

# 添加所有的边

def add_edges(nodes):

nodes_back = nodes

print(nodes_back)

for p in range(len(nodes_back)):

nodes_temp = nodes.copy()

from_nodes = nodes_temp.pop(p)

print("len of nodes_temp:" + str(len(nodes_temp)) + ",from_nodes:" + from_nodes)

nodes_temp_in = ",".join(nodes_temp)

nodes_temp_in = '(' + nodes_temp_in + ')'

sql = "SELECT * FROM AML.DEP_OFTEN_TRAD WHERE ACCOUNT_NO=" + from_nodes + " and CNTPRT_ACCOUNT_NO IN" + \

nodes_temp_in

result, stmt, conn = db2_query(sql)

if (result):

while (result):

print('-----------------')

print(result)

print(result['CNTPRT_ACCOUNT_NO'] + nodes_dict[result['CNTPRT_ACCOUNT_NO']])

print("add edges," + result['TRAD_VAL'] + " from:" + from_nodes + ",to:" + result['CNTPRT_ACCOUNT_NO'])

dot.edge(nodes_dict[from_nodes], nodes_dict[result['CNTPRT_ACCOUNT_NO']], result['TRAD_VAL'])

result = ibm_db.fetch_both(stmt)

# 关闭数据库连接

ibm_db.close(conn)

return dot

if __name__ == "__main__":

yaml_path = os.path.join('../', 'config.yaml')

with open(yaml_path, 'r') as f:

config = yaml.load(f)

dot = Digraph(

engine="circo",

comment='The Test Table',

format="png"

)

ACCOUNT_NO = '10100002181'

# 添加圆点A,A的标签是Dot A

dot.node('A', '中心客户', shape="rectangle", color="blue")

nodes_begin = datetime.now()

print(str(nodes_begin) + " nodes_begin")

dot, nodes, nodes_dict = add_nodes()

print(nodes_dict)

edges_begin = datetime.now()

print(str(edges_begin) + " edges_begin")

dot = add_edges(nodes)

print(dot.source)

render_begin = datetime.now()

print(str(render_begin) + " render_begin")

dot.render('./file/db2-table.gv', view=True)

测试流程图

用不同的参数,生成的2个图如下

841731-20190711153054354-2077477730.png

linux环境搭建

线上是不连外网的私有服务器,开始在离线环境安装,需要依赖的包太多,后来就在虚拟机里redhat6.6在线装好了。

redhat安装rpm依赖

#清除原有RHEL的YUM及相关软件包。

rpm -qa | grep yum | xargs rpm -e --nodeps

rpm -qa |grep python-urlgrabber|xargs rpm -e --nodeps

#安装rpm依赖包

rpm -ivh python-iniparse-0.3.1-2.1.el6.noarch.rpm

rpm -ivh python-urlgrabber-3.9.1-11.el6.noarch.rpm

rpm -ivh yum-metadata-parser-1.1.2-16.el6.x86_64.rpm

rpm -ivh yum-plugin-fastestmirror-1.1.30-41.el6.noarch.rpm yum-3.2.29-81.el6.centos.noarch.rpm

mv CentOS6-Base-163.repo /etc/yum.repos.d/

替换yum163源

cd /etc/yum.repos.d/

mv rhel-source.repo rhel-source.repo.bak

清理yum缓存

yum clean all

yum makecache

#测试

yum repolist

安装graphviz

yum install 'graphviz*'

#测试

which dot

#/usr/bin/dot

dot -V

#dot - graphviz version 2.26.0 (20091210.2329)

查看yum的安装日志,发现需要依赖2,30个包

解决依赖关系

--> 执行事务检查

---> Package graphviz.x86_64 0:2.26.0-10.el6 will be 安装

--> 处理依赖关系 libgd.so.2()(64bit),它被软件包 graphviz-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 libXpm.so.4()(64bit),它被软件包 graphviz-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 libXaw.so.7()(64bit),它被软件包 graphviz-2.26.0-10.el6.x86_64 需要

---> Package graphviz-devel.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-doc.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-gd.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-graphs.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-guile.x86_64 0:2.26.0-10.el6 will be 安装

--> 处理依赖关系 guile,它被软件包 graphviz-guile-2.26.0-10.el6.x86_64 需要

---> Package graphviz-java.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-lua.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-perl.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-php.x86_64 0:2.26.0-10.el6 will be 安装

--> 处理依赖关系 php(zend-abi) = 20090626,它被软件包 graphviz-php-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 php(api) = 20090626,它被软件包 graphviz-php-2.26.0-10.el6.x86_64 需要

---> Package graphviz-python.x86_64 0:2.26.0-10.el6 will be 安装

---> Package graphviz-ruby.x86_64 0:2.26.0-10.el6 will be 安装

--> 处理依赖关系 ruby,它被软件包 graphviz-ruby-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 libruby.so.1.8()(64bit),它被软件包 graphviz-ruby-2.26.0-10.el6.x86_64 需要

---> Package graphviz-tcl.x86_64 0:2.26.0-10.el6 will be 安装

--> 处理依赖关系 tcl >= 8.3,它被软件包 graphviz-tcl-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 tk,它被软件包 graphviz-tcl-2.26.0-10.el6.x86_64 需要

--> 处理依赖关系 libtk8.5.so()(64bit),它被软件包 graphviz-tcl-2.26.0-10.el6.x86_64 需要

--> 执行事务检查

---> Package gd.x86_64 0:2.0.35-11.el6 will be 安装

---> Package guile.x86_64 5:1.8.7-5.el6 will be 安装

---> Package libXaw.x86_64 0:1.0.11-2.el6 will be 安装

---> Package libXpm.x86_64 0:3.5.10-2.el6 will be 安装

---> Package php-common.x86_64 0:5.3.3-49.el6 will be 安装

---> Package ruby.x86_64 0:1.8.7.374-5.el6 will be 安装

---> Package ruby-libs.x86_64 0:1.8.7.374-5.el6 will be 安装

--> 处理依赖关系 libreadline.so.5()(64bit),它被软件包 ruby-libs-1.8.7.374-5.el6.x86_64 需要

---> Package tcl.x86_64 1:8.5.7-6.el6 will be 安装

---> Package tk.x86_64 1:8.5.7-5.el6 will be 安装

--> 执行事务检查

---> Package compat-readline5.x86_64 0:5.2-17.1.el6 will be 安装

--> 完成依赖关系计算

依赖关系解决

yum安装openssl-devel

#查看openssl安装包

rpm -aq|grep openssl

yum install openssl-devel -y

查看yum依赖

正在升级 : libcom_err-1.41.12-24.el6.x86_64 1/26

正在升级 : libselinux-2.0.94-7.el6.x86_64 2/26

正在升级 : krb5-libs-1.10.3-65.el6.x86_64 3/26

****************

Verifying : e2fsprogs-libs-1.41.12-21.el6.x86_64 23/26

Verifying : libselinux-2.0.94-5.8.el6.x86_64 24/26

Verifying : krb5-libs-1.10.3-33.el6.x86_64 25/26

Verifying : libss-1.41.12-21.el6.x86_64 26/26

python安装pip依赖

pip install -r requirement.txt

#Installing collected packages: PyYAML, ibm-db, tornado, graphviz

# Running setup.py install for PyYAML ... done

# Running setup.py install for ibm-db ... done

# Running setup.py install for tornado ... done

#Successfully installed PyYAML-5.1.1 graphviz-0.11.1 ibm-db-3.0.1 tornado-6.0.3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472593.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么读取matlab程序包,Nifti程序包,用于写入,读取和处理医学影像,适用于MATLAB

【实例简介】依赖于MATLAB,可以读取nii格式的文件,写入和操作输入的医学影像数据使用方法:1.下载压缩包并解压至MATLAB安装路径的toobox文件夹下 2.enjoy it!【实例截图】【核心代码】NIfTI_20140122├── affine.m├── bipolar.m├── bresenham_line3d.m├── clip_nii.…

天池 在线编程 牛郎织女(广度优先搜索)

文章目录1. 题目2. 解题1. 题目 描述 又到了七夕节,牛郎织女相约一起去一个n*m大小的迷宫maze里玩耍。 然而没过多久,他们就倒霉地走散了。 现在给定由.,*,S,T组成的矩阵maze, 其中.表示空地,*表示障碍物,S表示牛郎的位置 ,T表示织女的位置&…

BZOJ 1001 狼捉兔子

Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: 左上角点…

python中怎么复制代码_Python对象怎么引用_Python对象怎么复制代码_一聚教程网

本次文章要给大家讲解的是Python对象引用及复制代码,相信这也是大家问题比较大的一个点,下面为大家具体整理了操作过程,一起来了解下。可以说Python没有赋值,只有引用。你这样相当于创建了一个引用自身的结构,所以导致…

python为什么是蟒蛇_Python 为什么推荐蛇形命名法?

关于变量的命名,这又是一个容易引发程序员论战的话题。如何命名才能更具有可读性、易写性与明义性呢?众说纷纭。 本期“Python为什么”栏目,我们将聚焦于变量命名中的连接方式,来切入这块是非之地,想要回答的问题是——…

可视化工具Navicat for MySQL-操作三

五、备份和还原MySQL数据库 在数据库的管理中,备份和还原是必须做认真做的事情,如果疏忽或者做粗糙了,那么一旦数据库故障后果不堪设想,所以Navicat同样也有备份和还原的功能,相比较创建功能,其备份功能则…

python mysql返回,python操作mysql数据-执行语句返回值直接返回字典类型

fetchall()将结果放在二维数组里面,每一行的结果在元组里面import pymysqldef export(table_name):conn pymysql.connect(host 118.24.3.40,user jxz,password,dbjxz,port3306,charset utf8)cur conn.cursor()cur.execute(select * from %s%table_name)print(cu…

如何在python中打开文件_Python文件处理:创建、打开、追加、读、写

在Python中,不需要导入外部库来读取和写入文件。Python为创建、写入和读取文件提供了内置的函数。 在本文中,我们将学习 如何创建文本文件 如何将数据附加到文件中 如何读取文件 如何逐行读取文件 Python中的文件模式 如何创建文本文件 使用Python&#…

python中response.text_Sanic response text() 函数用法和示例

response.text() 功能:Sanic 返回纯文本内容给浏览器。作为一个完整功能的web网站,一般是不会返回纯文本内容的,特殊情况下可选择使用本函数。response.text() 语法def text(body,status200, headersNone,content_type"text/plain;chars…

天池 在线编程 排名查询

文章目录1. 题目2. 解题1. 题目 描述 给一个二维数组scores表示每个学生的各科成绩&#xff0c;求出学生中总成绩排名第K的索引。 如果成绩一样&#xff0c;越早出现的排名越高。 0 < scores[i][j] < 100 示例&#xff1a; 输入: scores: [[90, 80, 70], [90, 90, 90],…

matlab处理亮度不均匀,校正亮度不均匀问题并分析前景对象

预处理图像将图像读入工作区。I imread(rice.png);imshow(I)图像中心的背景亮度比底部亮度高。预处理图像&#xff0c;使背景亮度更加均匀。第一步&#xff0c;使用形态学开运算删除所有前景(米粒)。开运算会删除无法完全包含结构元素的小对象。定义半径为 15 的盘形结构元素&…

[CentOS] 打造vim环境

安装vim yum install vim-enhanced 安装git rpm -Uvh http://mirrors.ustc.edu.cn/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpmyum install git 安装bundle插件 git clone https://github.com/gmarik/vundle.git /data/vim/bundle/vundle 配置vim vim /etc/vimrc 在文件…

python接活网站_python能自己接活_python开发接活 - CSDN

Python远程连接oracle数据库概要1。Python连接数据库代码:def oracledbConnect(自我):试题:康涅狄格州 cx_ (\u201Cmdm\u201D、\u201Cnetqin123\u201D,\u201C: 1521 \/敏捷\u201D)光标 ()(\u201Cselect * from t_user \直接安装oracle数据库客户端:安装win32_11gR2_。4. 安装in…

python调用metasploit自动攻击_Python实现远程调用MetaSploit的方法

本文较为详细的讲述了Python实现远程调用MetaSploit的方法&#xff0c;对Python的学习来说有很好的参考价值。具体实现方法如下&#xff1a;(1)安装Python的msgpack类库&#xff0c;MSF官方文档中的数据序列化标准就是参照msgpack。rootkali:~# apt-get install python-setupto…

oracle 02085,OracleDBLink创建和维护以及ORA-02085解决办法

今天业务需要&#xff0c;要跨库查询Oracle数据&#xff0c;于是想到了dblink, 下面一一细说&#xff0c;Oracle DBLink。今天业务需要&#xff0c;要跨库查询Oracle数据&#xff0c;于是想到了dblink, 下面一一细说&#xff0c;&#xff0c;Oracle DBLink。首先Oracle DBLink …

C#单例模式详解

C#要实现单例模式必须要有以下三点&#xff1a; 声明私有静态成员、私有化构造函数、静态函数返回实例。 private static GameManager s_GameManagernull;private GameManager(){}public static GetInstance(){if(!s_GameManager){s_GameManagernew GameManager();}return s_Ga…

python的使用说明_Python 的基本使用说明

#-*- coding: utf-8 -*-#/usr/bin/env python Python中默认的编码格式是 ASCII 格式&#xff0c;在没修改编码格式时无法正确打印汉字&#xff0c;所以在读取中文时会报错。 解决方法为只要在文件开头加入 # -*- coding: UTF-8 -*- 或者 #codingutf-8 就行了 #导入模块 cnf#imp…

notepad python设置_NotePad++上配置Python

1.安装好python以及notepad2.打开notepad点击"运行"菜单->"运行"按钮(或者直接按F5)在弹出的窗口内输入以下命令(命令解释见文尾)后点击“保存”&#xff1a;cmd /k cd /d "$(CURRENT_DIRECTORY)" & python "$(FULL_CURRENT_PATH)&q…

oracle将字段nullable设为Y,从DB模型中消除NULLable列的选项(为了避免SQL的三值逻辑)?...

不久之前,我一直在阅读SQL and Relational Theory by C. J. Date一书.作者因批评sql的三值逻辑(3VL)而闻名.1)作者强调了为什么在sql中应该避免使用3VL,但他没有概述如果不允许使用可空列的数据库模型的样子.我已经考虑了一下,并提出了以下解决方案.如果我错过了其他设计方案,我…

在Delphi中使用indy SMTP发送gmail邮件[转]

在Delphi中使用indy SMTP发送gmail邮件[转] 2012-01-01 22:44:30| 分类&#xff1a; Delphi | 标签&#xff1a; |举报 |字号大中小 订阅 在Delphi中发送email很简单&#xff0c;发送ssl方式的gmail邮件也很简单&#xff0c;只要在使用的idSMTP上附加一个TIdSSLIOHandlerS…