利用python绘制并列的条形图。

(1)处理数据,计算每个区间的个数:

python怎么画条形图 python画条形图图加标签_python怎么画条形图

(2)plt.bar函数绘制条形图:

df = pd.read_excel('path of file ',sheet_name='Sheet1')

area_class = df['name']

lake_num = df['lake_number']

TP_lake_num = df['TP_2020_lake_number']

bar_width = 0.3  

index_lake = np.arange(len(area_class))

index_TP = index_lake + bar_width

plt.bar(index_lake, height=lake_num, width=bar_width, color='b', label='study_2020_lake')

plt.bar(index_TP, height=TP_lake_num, width=bar_width, color='g', label='TP_2020_lake')

plt.legend() 

plt.xticks(index_lake + bar_width/2, area_class)  

plt.ylabel('Number') 

plt.xlabel('Area (km$^{2}$)') 

plt.show()

显示结果:

python怎么画条形图 python画条形图图加标签_python怎么画条形图_02


(3)图形优化

为每个柱添加数据标签:

df = pd.read_excel('path of file',sheet_name='Sheet1')

fig, ax = plt.subplots()

area_class = df['name']

lake_num = df['lake_number']

TP_lake_num = df['TP_2020_lake_number']

bar_width = 0.3  

index_lake = np.arange(len(area_class))

index_TP = index_lake + bar_width

plt.bar(index_lake, height=lake_num, width=bar_width, color='b', label='study_lake')

for x, y in enumerate(df['lake_number'].values):
    
    # plt.text(x, y+1,y,ha='center', va='bottom')
    
    plt.text(x+0.1, y+1,y,ha='right',va='bottom')
    
plt.bar(index_TP, height=TP_lake_num, width=bar_width, color='g', label='TP_lake')

for a, b in enumerate(df['TP_2020_lake_number'].values):
    
    plt.text(a+0.1, b+1,b,ha='left',va='bottom')
    
plt.legend() 

plt.xticks(index_lake + bar_width/2, area_class)  

plt.ylabel('Number') 

plt.xlabel('Area (km$^{2}$)') 

plt.show()

显示结果:

python怎么画条形图 python画条形图图加标签_python怎么画条形图_03