1、在画多幅图时,每画一张图后都要使用 plt.close() 将图关闭,否则每张图都会累积画到下一幅图
2、画多个图表时可以使用 plt.figure(fig_i) 来创建
3、在同一个图中画多个子图时,可以使用 plt.subplot(221) ,221 的意思是,建立两行两列共 4 个图,并且把该图画在第一个图中
4、多个数据源画多个图表,且每个图表有多个子图,可使用如下代码:
def data_plt(data_tuple, save_path="YDY_fig", name=""): """ 数据可视化 :return: """ data_1, data_2, data_3, data_4 = data_tuple # 判断文件夹是否存在,如不存在则创建 path = os.getcwd() dir_path = path + "//%s" % save_path if not os.path.exists(dir_path): os.mkdir(dir_path) fig_i = 1 for i, col in enumerate(data_1.columns): # 过滤每列中的 NAN 值 data_1_filter_nan = df_filter_nan(data_1, col) data_2_filter_nan = df_filter_nan(data_2, col) data_3_filter_nan = df_filter_nan(data_3, col) data_4_filter_nan = df_filter_nan(data_4, col) data_filter_nan_tuple = data_1_filter_nan, data_2_filter_nan, data_3_filter_nan, data_4_filter_nan step = re.findall(r"[0-9]+", col)[0] plt.figure(fig_i) # 选择画在图表 fig_i sub_fig_i = 221 for data_i in data_filter_nan_tuple: NT = scs.norm.fit(data_i[col]) # `正态检验` plt.sca(plt.subplot(sub_fig_i)) # 画在子图 sub_fig_i plt.hist(data_i[col]) # 画图 plt.axis([0, 100, 0, len(data_i)]) plt.ylabel('Freq') plt.title(r'$ step=%s, \ \mu=%.2f ,\ \sigma=%.2f $' % (step, float(NT[0]), float(NT[1]))) plt.grid(True) sub_fig_i += 1 plt.savefig(r"%s/%s_%s.png" % (save_path, name, col)) fig_i += 1 # plt.show() # 关闭图 plt.close() return None