【python】plt绘图之柱状图

该代码示例展示了如何用Python的Matplotlib库创建并列柱状图,包括设置坐标轴、标题、图例、字体格式和大小,以及柱状图的符号填充。数据涉及CK+和JAFFE两个数据集,分别展示了原始脸、原始脸特征、情绪脸和情绪脸特征的比较。最后,图像被保存为jpg文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

并列柱状图:

包括坐标轴,标题,图例显示,字体格式及大小,柱状图的符号填充,图片的显示及保存等设置

import numpy as np
from pylab import mpl
import matplotlib.pyplot as plt

# 优化Matplotlib显示乱码的问题
mpl.rcParams['font.sans-serif'] = ['FangSong']
mpl.rcParams['axes.unicode_minus'] = False

# 第一组数据 CK+ Data
ck_OriginalFace = [, , ]   # 这里放数据,数组形式,如[1,2,3]
ck_OriginalFace_feature = [, , ]
ck_EigenFace = [, , ]
ck_EigenFace_feature = [, , ]
# 第二组数据 JAFFE Data
OriginalFace = [, , ]
OriginalFace_feature = [, , ]
EigenFace = [, , ]
EigenFace_feature = [, , ]

total_width, n = 0.8, 4   # 柱状图总宽度,有几组数据
width = total_width / n   # 单个柱状图的宽度
x1 = x - width / 4   # 第一组数据柱状图横坐标起始位置
x2 = x1 + width   # 第二组数据柱状图横坐标起始位置
x3 = x2 + width
x4 = x3 + width

marks = ["o","X","+","*","0"]

plt.subplot(1,2,1)
plt.bar(x1, ck_OriginalFace, width=width, edgecolor='k', hatch='**',color='w', label='原始脸', align='edge')     # 水平柱状图
plt.bar(x3, ck_OriginalFace_feature, width=width, edgecolor='k', hatch='xxx', color='w',label='原始脸特征', align='edge')
plt.bar(x2, ck_EigenFace, width=width, edgecolor='k', hatch='++', color='w', label='情绪脸', align='edge')  # 并列柱状图
plt.bar(x4, ck_EigenFace_feature, width=width, edgecolor='k', hatch='//', color='w', label='情绪脸特征', align='edge')

plt.xticks(x+2*width, duibi_name)    # 设置柱状图坐标轴文字
plt.xlabel('CK+数据集', fontproperties='FangSong', x=0.5, y=-0.2, fontsize=18)
plt.ylabel('得分', fontproperties='FangSong', fontsize=18)
plt.tick_params(labelsize=17)
plt.legend(loc="upper left")#  lower   right  显示图例

plt.subplot(1,2,2)
plt.bar(x1, OriginalFace, width=width, edgecolor='k', hatch='**',color='w', label='原始脸', align='edge')     # 水平柱状图
plt.bar(x2, OriginalFace_feature, width=width, edgecolor='k', hatch='xxx',color='w',label='原始脸特征',align='edge')
plt.bar(x3, EigenFace, width=width, edgecolor='k', hatch='++',color='w', label='情绪脸',align='edge')  # 并列柱状图
plt.bar(x4, EigenFace_feature, width=width, edgecolor='k', hatch='//',color='w', label='情绪脸特征',align='edge')

plt.xticks(x+2*width, duibi_name)    # 设置柱状图坐标轴文字
plt.xlabel('JAFFE数据集', fontproperties='FangSong', x=0.5, y=-0.2, fontsize=18)
plt.ylabel('得分', fontproperties='FangSong', fontsize=18)
plt.tick_params(labelsize=17)
plt.legend(loc="upper left")#  lower   right  显示图例

plt.suptitle('聚类评估指标', fontsize=18)   # 总标题
plt.savefig(r"D:\Python\pythonProject\lianxi\data_process\Plot\duibi-km.jpg", dpi=450, bbox_inches='tight')
plt.show()

在这里插入图片描述

参考链接:

https://blog.csdn.net/R_house/article/details/109225430

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dataloading...

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值