python动态横道图_10分钟用Python或MATLAB制作漂亮的甘特图(Gantt)

本文介绍了如何使用Python快速制作甘特图,包括生产调度和项目管理的示例。通过matplotlib库的plt.barh()绘制条形图实现,提供了代码模板和实际效果展示,帮助读者理解甘特图的绘制方法。

好久没有更新了,今天趁着放假,赶紧来水一期。嗯没错,就是这么直白。

说到生产调度,就不得不提甘特图这东西,可以用它来直观看调度的情况,非常方便。比如下图中:

Python画Gantt图

其实用Python画gantt原理是利用plt.barh()绘制水平方向的条形图,然后加以不同颜色区分表示。就是这么简单的。下面给出一个代码模板:import matplotlib.pyplot as plt

import numpy as np

ax=plt.gca()

[ax.spines[i].set_visible(False) for i in ["top","right"]]

def gatt(m,t):

"""甘特图

m机器集

t时间集

"""

for j in range(len(m)):#工序j

i=m[j]-1#机器编号i

if j==0:

plt.barh(i,t[j])

plt.text(np.sum(t[:j+1])/8,i,'J%s\nT%s'%((j+1),t[j]),color="white",size=8)

else:

plt.barh(i,t[j],left=(np.sum(t[:j])))

plt.text(np.sum(t[:j])+t[j]/8,i,'J%s\nT%s'%((j+1),t[j]),color="white",size=8)

if __name__=="__main__":

"""测试代码"""

m=np.random.randint(1,7,35)

t=np.random.randint(15,25,35)

gatt(m,t)

plt.yticks(np.arange(max(m)),np.arange(1,max(m)+1))

plt.show()

效果图如下:

这里讲讲plt.barh这个函数,官方barh()项目地址如下:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值