有时候为了直观展现图的信息,可以在大图中添加小子图的方式进行数据分析,如下图所示:
具体的代码如下:该图连接了数据库,当然重要的不是数据展示,而是添加子图的方法。
import matplotlib.pyplot as plt import MySQLdb as mdb import numpy as np from mpl_toolkits.axes_grid1.inset_locator import inset_axes from mpl_toolkits.axes_grid1.inset_locator import mark_inset def graph(): # 连接数据库 conn = mdb.connect(host='127.0.0.1', port=3306, user='root', passwd='root', db='alibaba_trace', charset='utf8') # 如果使用事务引擎,可以设置自动提交事务,或者在每次操作完成后手动提交事务conn.commit() conn.autocommit(1) # conn.autocommit(True) # 使用cursor()方法获取操作游标 cursor = conn.cursor() # 因该模块底层其实是调用CAPI的,所以,需要先得到当前指向数据库的指针。 try: cursor.execute("select machineID, count(id) from batch_instance where machineID != 0 group by machineID") records = cursor.fetchall() list_records = list(records) except: import traceback traceback.print_exc() # 发生错误时回滚 conn.rollback() finally: # 关闭游标连接 cursor.close() # 关闭数据库连接 conn.close() res = [] res[:] = map(list, list_records) machineID = [x[0] for x in res] instance_num = [x[1] for x in res] print(max(instance_num)) print(min(instance_num)) fig = plt.figure() ax1 = fig.add_subplot(1, 1, 1) # # cdf # hist, bin_edges = np.histogram(instance_num, bins=len(np.unique(instance_num))) # cdf = np.cumsum(hist / sum(hist)) # ax1.plot(bin_edges[1:], cdf, color='red', ls='-') # ax1.set_xlabel("instance number per machine") # ax1.set_ylabel("portion of machine") # plt.savefig('../../imgs_mysql/cdf_of_machine_instance.png') # # 直方图 ax1.hist(instance_num, normed=False, alpha=1.0, bins=100) ax1.set_xlabel('instance number per machine') ax1.set_ylabel('machine number') # cdf 要添加的子图 axins = inset_axes(ax1, width=1.5, height=1.5, loc='upper left') # ax1 大图 # width height分别为子图的宽和高 # loc 为子图在大图ax1中的相对位置 相应的值有 # upper left # lower left # lower right # right # center left # center right # lower center # upper center # center hist, bin_edges = np.histogram(instance_num, bins=len(np.unique(instance_num))) cdf = np.cumsum(hist / sum(hist)) axins.plot(bin_edges[1:], cdf, color='red', ls='-') axins.set_yticks([]) # axins.set_xlabel("instance number per machine") # axins.set_ylabel("portion of machine") plt.savefig("../../imgs_mysql/hist_of_machine_instance") plt.show() if __name__ == '__main__': graph()
以上这篇python 实现在一张图中绘制一个小的子图方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍python绘制多个子图的实例,包括了python绘制多个子图的实例的使用技巧和注意事项,需要的朋友参考一下 绘制八个子图 以上这篇python绘制多个子图的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
我正在学习python,而我一直坚持的是基于FLT列绘制一个直方图来指示每个过滤器。我有这个数据框: 我的目标是绘制FLT列,但要指示不同的过滤器:g、i、r和z。通过搜索如何绘制直方图,我可以根据MAG(幅值)绘制基本的直方图。理想情况下,我想要的是4种不同的颜色来表示不同的过滤器。我知道该图将有重叠的磁过滤器,但我同意它,因为我需要一个视觉,我可以放大,如果我有必要。 下面的代码是我现在拥有的
使用matplotlib时,我可以使用{importmatplotlib.pyplotas plt}因为我使用Tkinter,所以我也会使用PicreCanvasTkAgg来做同样的事情 有人能帮我在如何实现matplotlib的停顿效果在菲格勒CanvasTkAgg。
我有下面的脚本,当我在第二个数据集中有第三列时,它可以正常工作。现在,我想获得绘制的第一个带有错误条的直方图,第二个带有错误条。我可以从第二个plot命令中删除,但是gnuplot会抱怨没有为第二个直方图指定足够的数据。如果我删除
本文向大家介绍python在openstreetmap地图上绘制路线图的实现,包括了python在openstreetmap地图上绘制路线图的实现的使用技巧和注意事项,需要的朋友参考一下 利用python进行经纬度轨迹展示 嘿!各位好久不见,距离第一次发博客已经过去两年多了,本人也从本科生变成了研究生,好了书归正传,最近在做一个关于航班滑行路径轨迹的项目,目的是将航班的经纬度数据在地图上显现出来并
本文向大家介绍python实现在一个画布上画多个子图,包括了python实现在一个画布上画多个子图的使用技巧和注意事项,需要的朋友参考一下 matplotlib 是可以组合许多的小图, 放在一张大图里面显示的. 使用到的方法叫作 subplot. 均匀画图 使用import导入matplotlib.pyplot模块, 并简写成plt. 使用plt.figure创建一个图像窗口. 使用plt.sub