Pyecharts制作?;鶊D

由于需要梳理訂單的狀態變化,通過查找網上相關資料,了解到可以用?;鶊D的形式呈現,同時也了解了下用pyecharts實現的代碼編制方法,特編寫此文稿作為總結。(PS:圖片中的數據不代表真實業務數據。)

1.在起初操作時,發現自己import sankey報錯,后發現是源于自己pyecharts的版本不對,目前自己的版本是0.5.11,如果有遇到同樣錯誤的小伙伴,可以注意檢查下自己的pyecharts版本是否正確。


pyecharts版本

2.由于Pyecharts不顯示values值,但做PPT的時候就要截圖,所以就在標簽后面帶上相應的數值,便于截圖直觀展示。

3.關于轉態之間轉換連接線的顏色,可以設置為連接的源頭或去向分支的顏色,但從美觀上考慮,建議將其設置為統一的淺色調。

4.python的logging模塊,可用于輸出運行日志,可以設置輸出日志的等級、日志保存路徑、日志文件回滾等,關于該模塊的使用介紹,詳見鏈接:(https://www.cnblogs.com/liujiacai/p/7804848.html)
在python的頭部加入如下代碼,可查看運行日志:

import logging
import logging.config

logging.basicConfig(
    format='%(name)s:%(lineno)d - %(levelname)s - %(message)s',
    level=logging.DEBUG)

繪制?;鶊D的整體代碼如下:

from pyecharts import Sankey
nodes = [
    {'name': '創建訂單-1828'}, {'name': '未支付-935'}, {'name': '已支付-893'},
    {'name': '未發貨-114'}, {'name': '已發貨-779'}, {'name': '未收貨-111'},
    {'name': '已收貨-669'}, {'name': '未刪除-813'}, {'name': '已刪除-122'},
    {'name': '已退款-51'}, {'name': '未退款-65'}, {'name': '待收貨-109'}, {'name': '訂單完成-601'},
]#此處羅列各分支名稱,后面的數字代表具體的量值(注:因為pyecharts無法直接顯示value,所以需要這樣標注)。
links = [
    {'source': '創建訂單-1828', 'target': '未支付-935', 'value': 935},
    {'source': '創建訂單-1828', 'target': '已支付-893', 'value': 893},
    {'source': '未支付-935', 'target': '未刪除-813', 'value': 813},
    {'source': '未支付-935', 'target': '已刪除-122', 'value': 122},
    {'source': '已支付-893', 'target': '未發貨-114', 'value': 114},
    {'source': '已支付-893', 'target': '已發貨-779', 'value': 779},
    {'source': '未發貨-114', 'target': '已退款-51', 'value': 49},
    {'source': '未發貨-114', 'target': '未退款-65', 'value': 65},
    {'source': '已發貨-779', 'target': '未收貨-111', 'value': 111},
    {'source': '已發貨-779', 'target': '已收貨-669', 'value': 668},
    {'source': '未收貨-111', 'target': '待收貨-109', 'value': 109},
    {'source': '未收貨-111', 'target': '已退款-51', 'value': 2},
    {'source': '已收貨-669', 'target': '訂單完成-601', 'value': 601},
]#此處羅列各分支之間的關聯關系,source表示節點,target表示終點,value表示狀態轉化的量值。

snakey = Sankey(
        title="訂單狀態轉化圖",#主標題名稱
        title_pos='center',#主標題距離左側距離,有’auto’, ‘left’, ‘right’, 'center’可選,也可為百分比或整數
        title_top='top',#主標題距離頂部距離,有’top’, ‘middle’, 'bottom’可選,也可為百分比或整數
        title_color='#595959',#主標題文本顏色,顏色的取值直接輸入英文單詞也可支持;十六進制大小寫均可。
        title_text_size=30,#主標題文本字體大小
        width=1800,#設置圖的寬度
        height=600#設置圖的高度
)
snakey.add(
    "",#按鈕,用來控制是否顯示圖標。若不顯示,可以設置為‘空格’,不能缺省。
    nodes,#輸入節點
    links,#輸入關系
    line_opacity=0.2,#曲線色彩深度
    line_curve=0.6,#曲線弧度
    line_width=15,#曲線寬度
    line_color="gray",#設置轉態轉化之間連接線的顏色,可以填寫顏色,也可以設置為target或source
    is_label_show=True,#是否顯示標簽
    sankey_node_width=30,#各節點的寬度
    sankey_node_gap=8,#同列上下節點之間的距離
    label_text_size=20,#設置標簽字體大小
    label_pos="right",#標簽位置,可以設置靠左或者靠右
)
snakey.render()
生成的示例圖
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容