Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Python当打之年
Python当打之年ke hadapan
2023-08-09 16:06:302347semak imbas


hoday Saya akan memperkenalkan kepada anda bagaimana menggunakan perpustakaan Matplotlib Python untuk menarik grafik y-y-axis dan tetapan legenda sebarang soalan atau cadangan, anda boleh menghantar mesej peribadi kepada editor .
Pratonton pemaparan:

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Sampel data:
df = pd.read_csv('jobdata.csv')
Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

colors = ["#51C1C8", "#536D84","#E96279"]
plt.figure(figsize=(16, 8))
ax1 = plt.subplot(111)
ax1.set_ylim(0,1200)
lin0 = ax1.plot(x_data, y_data1, marker='o', color=colors[0], label='岗位数量') 
for x, y in enumerate(y_data1):
    plt.text(x - 0.2, y+5, y)
ax1.set_ylabel('岗位数量',fontsize=12)
plt.legend()
plt.title("各城市Java岗位数量")
plt.show()

1. Carta garis paksi-y berganda

1. Carta garis nombor kedudukan
2. Tambahkan paksi-y melalui ax1.twinx( ):

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

# 增加y轴
ax2 = ax1.twinx()

ax2.set_ylim(0,60)
lin1 = ax2.plot(x_data, y_data2, linestyle='--', marker='o', c=colors[1], label='平均最低薪资') 
for x, y in enumerate(y_data2):
    plt.text(x - 0.1, y+1, y)
lin2 = ax2.plot(x_data, y_data3, linestyle='--', marker='o', c=colors[2], label='平均最高薪资')
for x, y in enumerate(y_data3):
    plt.text(x - 0.1, y+1, y)
ax2.set_ylabel('平均薪资(万/年)',fontsize=12)
plt.legend()
plt.title("各城市Java岗位数量和薪资水平状况")
plt.show()

重点:细心的小伙伴可能发现了图没有问题,但是右上角的图例只显示了平均最低薪资和平均最薪资,但是岗位数量的图例并没有显示。

3. 单独设置图例

ax1.legend(loc='best')
ax2.legend(loc='best')

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

看着感觉没什么变化,实际上仔细看会发现平均最低薪资、平均最高薪资、岗位数量三个图例都显示出来了,只不过岗位数量图例被盖住了,我们可以移动一下位置看看:
ax1.legend(loc=2)
ax2.legend(loc=1)

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

这样看就比较直观了,但是我就想把三个图例放一起不可以吗?

当然可以!

3. 设置组合图例

lines = lin0+lin1+lin2
labs = [label.get_label() for label in lines]
plt.legend(lines,labs)

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)


大功告成!

但是!如果是柱状图+折线图的情况,效果还一样吗?

但是!如果是柱状图+折线图的情况,效果还一样吗?

但是!如果是柱状图+折线图的情况,效果还一样吗?


2、双y轴柱状图+折线图

1. 修改岗位数量为柱状图

plt.figure(figsize=(16, 8))
a1 = plt.subplot(111)
a1.set_ylim(0,1200)
bar = a1.bar(x_data, y_data1, color=colors[0], label='岗位数量') 
for x, y in enumerate(y_data1):
    plt.text(x - 0.2, y+5, y)
a1.set_ylabel('岗位数量',fontsize=12)

...

lines = bar+lin1+lin2
labs = [label.get_label() for label in lines]
plt.legend(lines,labs)

直接报错了!Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Jenis gesaan tidak konsisten Ia jelas merupakan masalah dengan jenis bar dan garisan Mari kita semak kod sumber:

matplotlib.axes.Axes.plot:

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

Axes.bar:

Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)

🎜
ax.plot mengembalikan senarai jenis Line2D dan ax.bar mengembalikan tuple jenis patches.
Selepas mencari punca, kami hanya membuat gabungan line2D dan patch.

2. 设置Line2D和patches的组合图例

legend_handles = [ 
    Line2D([], [], linewidth=1, ls='--', lw=2, c=colors[2], label='平均最高薪资'),
    Line2D([], [], linewidth=1, lw=2, c=colors[1], label='平均最低薪资'),
    patches.Rectangle((0, 0), 1, 1, facecolor=colors[0],label='岗位数量')
]
plt.legend(handles=legend_handles, loc='best', fontsize=14)
效果:
Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda)
其他参数大家可以自行尝试修改,对比前后效果,加深理解。

Atas ialah kandungan terperinci Python-matplotlib |. Lukiskan grafik dwi paksi-y (tetapan legenda). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:Python当打之年. Jika ada pelanggaran, sila hubungi admin@php.cn Padam