日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python画代码流程图_Python使用graphviz画流程图过程解析

發布時間:2025/3/19 python 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python画代码流程图_Python使用graphviz画流程图过程解析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題描述

項目中需要用到流程圖,如果用js的echarts處理,不同層級建動態計算位置比較復雜,考慮用python來實現

測試demo

實現效果如下

完整代碼

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)

總結

以上是生活随笔為你收集整理的python画代码流程图_Python使用graphviz画流程图过程解析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。