from matplotlib import pyplot as plt
import random
from pylab import mpl
# 设置中文显示
mpl.rcParams["font.sans-serif"] = ["SimHei"]
mpl.rcParams["axes.unicode_minus"] = False
x = range(60)
y_shanghai = [random.uniform(15, 18) for i in x]
y_beijing = [random.uniform(1, 3) for i in x]
# 设置图像大小及清晰度
fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(20, 8), dpi=100)
# 绘制图像
axes[0].plot(x, y_shanghai, label="上海")
axes[1].plot(x, y_beijing, color="r", linestyle="--", label="北京")
x_ticks_label = ["11点{}分".format(i) for i in x]
y_ticks = range(40)
x_ticks = x[::5]
# 设置坐标轴刻度
axes[0].set_xticks(x_ticks)
axes[0].set_yticks(y_ticks[::5])
axes[0].set_xticklabels(x_ticks_label[::5])
axes[1].set_xticks(x_ticks)
axes[1].set_yticks(y_ticks[::5])
axes[1].set_xticklabels(x_ticks_label[::5])
# 设置网格
axes[0].grid(True, linestyle="--", alpha=1)
axes[1].grid(True, linestyle="--", alpha=1)
# 设置坐标轴含义
axes[0].set_xlabel("时间")
axes[0].set_ylabel("温度")
axes[0].set_title("中午温度", fontsize=20)
axes[1].set_xlabel("时间")
axes[1].set_ylabel("温度")
axes[1].set_title("中午温度", fontsize=20)
# 添加图例
axes[0].legend(loc="best")
axes[1].legend(loc="best")
# 图像保存
plt.savefig("./test.png")
# 展示图像
plt.show()
matplotlib在多个坐标系下绘制折线图像(模板)
最新推荐文章于 2024-01-25 15:06:55 发布