python 實(shí)現(xiàn)在一張圖中繪制一個(gè)小的子圖方法
有時(shí)候?yàn)榱酥庇^展現(xiàn)圖的信息,可以在大圖中添加小子圖的方式進(jìn)行數(shù)據(jù)分析,如下圖所示:

具體的代碼如下:該圖連接了數(shù)據(jù)庫,當(dāng)然重要的不是數(shù)據(jù)展示,而是添加子圖的方法。
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():
# 連接數(shù)據(jù)庫
conn = mdb.connect(host='127.0.0.1', port=3306, user='root', passwd='root', db='alibaba_trace', charset='utf8')
# 如果使用事務(wù)引擎,可以設(shè)置自動(dòng)提交事務(wù),或者在每次操作完成后手動(dòng)提交事務(wù)conn.commit()
conn.autocommit(1) # conn.autocommit(True)
# 使用cursor()方法獲取操作游標(biāo)
cursor = conn.cursor()
# 因該模塊底層其實(shí)是調(diào)用CAPI的,所以,需要先得到當(dāng)前指向數(shù)據(jù)庫的指針。
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()
# 發(fā)生錯(cuò)誤時(shí)回滾
conn.rollback()
finally:
# 關(guān)閉游標(biāo)連接
cursor.close()
# 關(guān)閉數(shù)據(jù)庫連接
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中的相對(duì)位置 相應(yīng)的值有
# 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 實(shí)現(xiàn)在一張圖中繪制一個(gè)小的子圖方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python?Dash框架在數(shù)據(jù)可視化儀表板中的應(yīng)用與實(shí)踐記錄
Python的Plotly?Dash庫提供了一種簡便且強(qiáng)大的方式來構(gòu)建和展示互動(dòng)式數(shù)據(jù)儀表板,本篇文章將深入探討如何使用Dash設(shè)計(jì)一個(gè)互動(dòng)數(shù)據(jù)儀表板,并通過代碼示例幫助讀者理解如何實(shí)現(xiàn)這一過程,感興趣的朋友一起看看吧2025-03-03
Django3.0 異步通信初體驗(yàn)(小結(jié))
這篇文章主要介紹了Django3.0 異步通信初體驗(yàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
python實(shí)現(xiàn)人機(jī)對(duì)戰(zhàn)的五子棋游戲
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)人機(jī)對(duì)戰(zhàn)的五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
Python學(xué)習(xí)筆記之Django創(chuàng)建第一個(gè)數(shù)據(jù)庫模型的方法
今天小編就為大家分享一篇Python學(xué)習(xí)筆記之Django創(chuàng)建第一個(gè)數(shù)據(jù)庫模型的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08
Python中標(biāo)準(zhǔn)庫OS的常用方法總結(jié)大全
python中的OS庫提供了使用各種操作系統(tǒng)功能的接口。是經(jīng)常用到的一個(gè)庫,所以這篇文章主要給大家總結(jié)介紹了關(guān)于Python中標(biāo)準(zhǔn)庫OS的常用方法,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),需要的朋友們下面來一起看看吧。2017-07-07

